ServiceThrottlingBehavior Classe

Definição

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.

Aplica-se a