Compartilhar via


Utilizando o ServiceThrottlingBehavior para controlar o desempenho de serviço do WCF

A classe ServiceThrottlingBehavior 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 propriedade MaxConcurrentCalls para especificar o número máximo de mensagens ativamente processando em uma classe ServiceHost e a propriedade MaxConcurrentInstances para especificar o número máximo de objetos InstanceContext no serviço.

Como determinar as configurações dessas propriedades geralmente ocorre após a experiência real de execução do aplicativo em relação a cargas, as configurações para as propriedades ServiceThrottlingBehavior normalmente são 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 de tempo de execução depende dos valores e das propriedades ConcurrencyMode e InstanceContextMode, que controlam quantas mensagens podem ser executadas dentro de uma operação de uma só vez e do tempo de vida do serviço InstanceContext em relação às sessões de canal de entrada, respectivamente.

Para obter detalhes, consulte MaxConcurrentCalls e MaxConcurrentInstances.

Confira também