Compartilhar via


Usando ServiceThrottlingBehavior para controlar o desempenho do serviço WCF

A ServiceThrottlingBehavior classe expõe as 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 aplicativo WCF (Windows Communication Foundation).

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

Use a MaxConcurrentCalls propriedade para especificar o número máximo de mensagens que estão sendo 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 definição das configurações dessas propriedades geralmente é feita após a experiência prática de rodar o aplicativo sob carga, as configurações das propriedades ServiceThrottlingBehavior são normalmente especificadas em um arquivo de configuração de aplicativo usando o elemento <serviceThrottling>.

O exemplo de código a seguir mostra o uso da classe ServiceThrottlingBehavior de um arquivo de configuração de aplicativo que define as propriedades MaxConcurrentSessions, MaxConcurrentCalls e MaxConcurrentInstances como 1 como um exemplo trivial. A experiência do mundo real determina as configurações ideais para qualquer aplicativo específico.

<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 ConcurrencyMode e InstanceContextMode, que controlam quantas mensagens podem ser executadas dentro de uma operação ao mesmo tempo e quanto à duração de vida do serviço InstanceContext em relação às sessões de canal de entrada, respectivamente.

Para obter detalhes, consulte MaxConcurrentCallse MaxConcurrentInstances.

Consulte também