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.