Partilhar via


ServiceThrottlingBehavior Classe

Definição

Define as configurações de taxa de transferência de 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 exemplo de código a seguir mostra o uso de um arquivo de configuração de ServiceThrottlingBehavior aplicativo que define as MaxConcurrentSessionsMaxConcurrentCallspropriedades e MaxConcurrentInstances as propriedades como 1 como exemplo. A experiência do mundo real determina quais são as configurações ideais para qualquer aplicativo específico.

<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>

Comentários

Use a ServiceThrottlingBehavior classe para controlar várias configurações de taxa de transferência que ajudam a impedir que seu aplicativo ficar sem memória.

A MaxConcurrentCalls propriedade limita o número de mensagens que atualmente processam em um ServiceHost.

A MaxConcurrentInstances propriedade limita o número de InstanceContext objetos que são executados ao mesmo tempo em 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 requer experiência na execução do aplicativo, usar o ServiceThrottlingBehavior arquivo de configuração por meio de um aplicativo é o método mais comum de modificar a execução para maximizar o desempenho do serviço.

Observação

Um rastreamento é gravado sempre que o valor dessas propriedades é atingido. O primeiro rastreamento é gravado como um aviso.

Você também pode definir os valores desse atributo usando o <elemento serviceThrottling> em um arquivo de configuração de aplicativo.

Construtores

ServiceThrottlingBehavior()

Inicializa uma nova instância da classe ServiceThrottlingBehavior.

Propriedades

MaxConcurrentCalls

Obtém ou define um valor que especifica o número máximo de mensagens processando ativamente em um ServiceHost.

MaxConcurrentInstances

Obtém ou define um valor que especifica o número máximo de objetos InstanceContext 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 objeto ServiceHost pode aceitar simultaneamente.

Métodos

Equals(Object)

Determina se o objeto especificado é igual ao objeto atual.

(Herdado de Object)
GetHashCode()

Serve como a função de hash padrão.

(Herdado de Object)
GetType()

Obtém o Type da instância atual.

(Herdado de Object)
MemberwiseClone()

Cria uma cópia superficial do Object atual.

(Herdado de Object)
ToString()

Retorna uma cadeia de caracteres que representa o objeto atual.

(Herdado de Object)

Implantações explícitas de interface

IServiceBehavior.AddBindingParameters(ServiceDescription, ServiceHostBase, Collection<ServiceEndpoint>, BindingParameterCollection)

Configura as associações para dar suporte ao comportamento do serviço.

IServiceBehavior.ApplyDispatchBehavior(ServiceDescription, ServiceHostBase)

Configura o serviço para dar suporte ao comportamento do serviço.

IServiceBehavior.Validate(ServiceDescription, ServiceHostBase)

Valida que o serviço e o host podem dar suporte ao comportamento de serviço.

Aplica-se a