Używanie elementu ServiceThrottlingBehavior do kontrolowania wydajności programu WCF
Klasa ServiceThrottlingBehavior uwidacznia właściwości, których można użyć, aby ograniczyć liczbę wystąpień lub sesji tworzonych na poziomie aplikacji. Korzystając z tego zachowania, można dostosować wydajność aplikacji Windows Communication Foundation (WCF).
Kontrolowanie wystąpień usługi i współbieżnych wywołań
MaxConcurrentCalls Użyj właściwości , aby określić maksymalną liczbę komunikatów aktywnie przetwarzanych w ServiceHost klasie, a MaxConcurrentInstances właściwość określa maksymalną liczbę InstanceContext obiektów w usłudze.
Ponieważ określenie ustawień tych właściwości odbywa się zwykle po uruchomieniu aplikacji w środowisku rzeczywistym przed obciążeniami, ustawienia ServiceThrottlingBehavior właściwości są zwykle określane w pliku konfiguracji aplikacji przy użyciu <elementu serviceThrottling> .
Poniższy przykład kodu przedstawia użycie ServiceThrottlingBehavior klasy z pliku konfiguracji aplikacji, który ustawia MaxConcurrentSessionswłaściwości , MaxConcurrentCallsi MaxConcurrentInstances na wartość 1 jako przykład prosty. Środowisko rzeczywiste określa optymalne ustawienia dla każdej konkretnej aplikacji.
<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>
Dokładne zachowanie czasu wykonywania zależy od wartości ConcurrencyMode właściwości i InstanceContextMode , które kontrolują, ile komunikatów może być wykonywanych wewnątrz operacji jednocześnie oraz okresy istnienia usługi InstanceContext względem sesji kanału przychodzącego, odpowiednio.
Aby uzyskać szczegółowe informacje, zobacz MaxConcurrentCalls, i MaxConcurrentInstances.