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.