ServiceThrottlingBehavior Classe
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Configura as definições de rendimento em tempo de execução que permitem ajustar o desempenho do serviço.
public ref class ServiceThrottlingBehavior : System::ServiceModel::Description::IServiceBehavior
public class ServiceThrottlingBehavior : System.ServiceModel.Description.IServiceBehavior
type ServiceThrottlingBehavior = class
interface IServiceBehavior
Public Class ServiceThrottlingBehavior
Implements IServiceBehavior
- Herança
-
ServiceThrottlingBehavior
- Implementações
Exemplos
O seguinte exemplo de código mostra a utilização de ServiceThrottlingBehavior de um ficheiro de configuração de aplicação que define as MaxConcurrentSessionspropriedades , MaxConcurrentCalls, e MaxConcurrentInstances para 1 como exemplo. A experiência real determina quais são as definições ótimas para cada 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>
Observações
Use a ServiceThrottlingBehavior classe para controlar várias definições de throughput que ajudem a evitar que a sua aplicação fique sem memória.
A MaxConcurrentCalls propriedade limita o número de mensagens que atualmente são processadas através de um ServiceHost.
A MaxConcurrentInstances propriedade limita o número de InstanceContext objetos que se executam simultaneamente através de um ServiceHost.
A MaxConcurrentSessions propriedade limita o número de sessões que um ServiceHost objeto pode aceitar.
Como o balanceamento de carga em tempo de execução exige experiência a executar a aplicação, usar o ficheiro ServiceThrottlingBehavior de configuração através de uma aplicação é o método mais comum para modificar a execução e maximizar o desempenho do serviço.
Note
Um traço é escrito sempre que o valor destas propriedades é atingido. O primeiro traço está escrito como um aviso.
Também pode definir os valores deste atributo usando o <elemento serviceThrottling> num ficheiro de configuração da aplicação.
Construtores
| Name | Description |
|---|---|
| ServiceThrottlingBehavior() |
Inicializa uma nova instância da ServiceThrottlingBehavior classe. |
Propriedades
| Name | Description |
|---|---|
| MaxConcurrentCalls |
Obtém ou define um valor que especifica o número máximo de mensagens a serem processadas ativamente através de um ServiceHost. |
| MaxConcurrentInstances |
Obtém ou define um valor que especifica o número máximo de InstanceContext objetos no serviço que podem ser executados ao mesmo tempo. |
| MaxConcurrentSessions |
Obtém ou define um valor que especifica o número máximo de sessões que um ServiceHost objeto pode aceitar de cada vez. |
Métodos
| Name | Description |
|---|---|
| Equals(Object) |
Determina se o objeto especificado é igual ao objeto atual. (Herdado de Object) |
| GetHashCode() |
Serve como função de hash predefinida. (Herdado de Object) |
| GetType() |
Obtém o Type da instância atual. (Herdado de Object) |
| MemberwiseClone() |
Cria uma cópia superficial do atual Object. (Herdado de Object) |
| ToString() |
Devolve uma cadeia que representa o objeto atual. (Herdado de Object) |
Implementações de Interface Explícita
| Name | Description |
|---|---|
| IServiceBehavior.AddBindingParameters(ServiceDescription, ServiceHostBase, Collection<ServiceEndpoint>, BindingParameterCollection) |
Configura as ligações para suportar o comportamento do serviço. |
| IServiceBehavior.ApplyDispatchBehavior(ServiceDescription, ServiceHostBase) |
Configura o serviço para suportar o comportamento do serviço. |
| IServiceBehavior.Validate(ServiceDescription, ServiceHostBase) |
Valida que o serviço e o host conseguem suportar o comportamento do serviço. |