Поделиться через


Использование ServiceThrottlingBehavior для управления производительностью службы WCF

Класс ServiceThrottlingBehavior представляет свойства, которые можно использовать для ограничения количества экземпляров или сеансов, создаваемых на уровне приложения. С помощью этого поведения можно точно настроить производительность приложения Windows Communication Foundation (WCF).

Управление экземплярами службы и одновременными вызовами

С помощью свойства MaxConcurrentCalls задайте максимальное количество одновременно обрабатываемых сообщений в классе ServiceHost, а с помощью свойства MaxConcurrentInstances задайте максимальное количество объектов InstanceContext в службе.

Так как определение параметров этих свойств обычно происходит после реального выполнения приложения с нагрузкой, параметры ServiceThrottlingBehavior свойств обычно указываются в файле конфигурации приложения с помощью <элемента serviceThrottling> .

В следующем примере кода показано использование класса ServiceThrottlingBehavior из файла конфигурации приложения, который, в качестве упрощенного примера, задает для свойств MaxConcurrentSessions, MaxConcurrentCalls и MaxConcurrentInstances значение 1. Фактические условия определяют оптимальные параметры для каждого конкретного приложения.

<configuration>
  <appSettings>
    <!-- use appSetting to configure base address provided by host -->
    <add key="baseAddress" value="http://localhost:8080/ServiceMetadata" />
  </appSettings>
  <system.serviceModel>
    <services>
      <service 
        name="Microsoft.WCF.Documentation.SampleService"
        behaviorConfiguration="Throttled" >
        <host>
          <baseAddresses>
            <add baseAddress="http://localhost:8080/SampleService"/>
          </baseAddresses>
        </host>
        <endpoint
          address=""
          binding="wsHttpBinding"
          contract="Microsoft.WCF.Documentation.ISampleService"
         />
        <endpoint
          address="mex"
          binding="mexHttpBinding"
          contract="IMetadataExchange"
         />
      </service>
    </services>
    <behaviors>
      <serviceBehaviors>
        <behavior  name="Throttled">
          <serviceThrottling 
            maxConcurrentCalls="1" 
            maxConcurrentSessions="1" 
            maxConcurrentInstances="1"
          />
          <serviceMetadata 
            httpGetEnabled="true" 
            httpGetUrl=""
          />
        </behavior>
      </serviceBehaviors>
    </behaviors>
  </system.serviceModel>
</configuration>

Точное поведение времени выполнения зависит от значений свойств ConcurrencyMode и InstanceContextMode, которые управляют количеством сообщений, которые могут обрабатываться в операции одновременно, и временем существования службы InstanceContext относительно сеансов входящих каналов, соответственно.

Дополнительные сведения см. в разделах MaxConcurrentCalls и MaxConcurrentInstances.

См. также