Řízení výkonu služby WCF pomocí třídy ServiceThrottlingBehavior
Třída ServiceThrottlingBehavior zveřejňuje vlastnosti, které můžete použít k omezení počtu instancí nebo relací vytvořených na úrovni aplikace. Pomocí tohoto chování můžete vyladit výkon aplikace WCF (Windows Communication Foundation).
Řízení instancí služby a souběžných volání
MaxConcurrentCalls Pomocí vlastnosti určete maximální počet zpráv aktivně zpracovávaných v rámci ServiceHost třídy a MaxConcurrentInstances vlastnost určit maximální počet InstanceContext objektů ve službě.
Vzhledem k tomu, že určení nastavení těchto vlastností se obvykle provádí po skutečném prostředí, kdy je aplikace spuštěna proti načtení, nastavení vlastností ServiceThrottlingBehavior se obvykle zadává v konfiguračním souboru aplikace pomocí elementu <serviceThrottling> .
Následující příklad kódu ukazuje použití třídy z konfiguračního ServiceThrottlingBehavior souboru aplikace, který nastaví MaxConcurrentSessions, MaxConcurrentCallsa MaxConcurrentInstances vlastnosti na hodnotu 1 jako triviální příklad. Prostředí reálného světa určuje optimální nastavení pro každou konkrétní aplikaci.
<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>
Přesné chování za běhu závisí na hodnotách a InstanceContextMode vlastnostechConcurrencyMode, které řídí, kolik zpráv se může spustit uvnitř operace najednou, a životnosti služby InstanceContext vzhledem k relacím příchozího kanálu.
Podrobnosti naleznete v části MaxConcurrentCallsa MaxConcurrentInstances.