Partilhar via


Usando ServiceThrottlingBehavior para controlar o desempenho do serviço WCF

A ServiceThrottlingBehavior classe expõe propriedades que você pode usar para limitar quantas instâncias ou sessões são criadas no nível do aplicativo. Usando esse comportamento, você pode ajustar o desempenho do seu aplicativo Windows Communication Foundation (WCF).

Controlando instâncias de serviço e chamadas simultâneas

Use a MaxConcurrentCalls propriedade para especificar o número máximo de mensagens processadas ativamente em uma ServiceHost classe e a MaxConcurrentInstances propriedade para especificar o número máximo de InstanceContext objetos no serviço.

Como a determinação das configurações para essas propriedades geralmente ocorre após a experiência real de execução do aplicativo contra cargas, as configurações para as ServiceThrottlingBehavior propriedades normalmente são especificadas em um arquivo de configuração do aplicativo usando o <elemento serviceThrottling> .

O exemplo de código a seguir mostra o uso da ServiceThrottlingBehavior classe de um arquivo de configuração de aplicativo que define as MaxConcurrentSessionspropriedades , MaxConcurrentCallse e MaxConcurrentInstances como 1 como um exemplo trivial. A experiência do mundo real determina as configurações ideais para qualquer aplicação em particular.

<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>

O comportamento exato em tempo de execução depende dos valores das propriedades e InstanceContextMode , que controlam quantas mensagens podem ser executadas dentro de uma operação ao mesmo tempo e os tempos de vida do serviço InstanceContext em relação às sessões de ConcurrencyMode canal de entrada, respectivamente.

Para obter detalhes, consulte MaxConcurrentCalls, e MaxConcurrentInstances.

Consulte também