Compartilhar via


SqlWorkflowInstanceStore.RunnableInstancesDetectionPeriod Propriedade

Definição

Especifica o período após o qual o repositório de instâncias de fluxo de trabalho do SQL executará uma tarefa de detecção para detectar qualquer instância de fluxo de trabalho executável ou ativável no banco de dados de persistência após o ciclo de detecção anterior.

public:
 property TimeSpan RunnableInstancesDetectionPeriod { TimeSpan get(); void set(TimeSpan value); };
public TimeSpan RunnableInstancesDetectionPeriod { get; set; }
member this.RunnableInstancesDetectionPeriod : TimeSpan with get, set
Public Property RunnableInstancesDetectionPeriod As TimeSpan

Valor da propriedade

Retorna TimeSpan.

Exemplos

O exemplo de código a seguir demonstra o uso de RunnableInstancesDetectionPeriod em um SqlWorkflowInstanceStore.

static void Main(string[] args)
{
    // Create service host.
    WorkflowServiceHost host = new WorkflowServiceHost(new CountingWorkflow(), new Uri(hostBaseAddress));

    // Add service endpoint.
    host.AddServiceEndpoint("ICountingWorkflow", new BasicHttpBinding(), "");

    // Define SqlWorkflowInstanceStoreBehavior:
    //   Set interval to renew instance lock to 5 seconds.
    //   Set interval to check for runnable instances to 2 seconds.
    //   Instance Store does not keep instances after it is completed.
    //   Select exponential back-off algorithm when retrying to load a locked instance.
    //   Instance state information is compressed using the GZip compressing algorithm.
    SqlWorkflowInstanceStoreBehavior instanceStoreBehavior = new SqlWorkflowInstanceStoreBehavior(connectionString);
    instanceStoreBehavior.HostLockRenewalPeriod = new TimeSpan(0, 0, 5);
    instanceStoreBehavior.RunnableInstancesDetectionPeriod = new TimeSpan(0, 0, 2);
    instanceStoreBehavior.InstanceCompletionAction = InstanceCompletionAction.DeleteAll;
    instanceStoreBehavior.InstanceLockedExceptionAction = InstanceLockedExceptionAction.AggressiveRetry;
    instanceStoreBehavior.InstanceEncodingOption = InstanceEncodingOption.GZip;
    host.Description.Behaviors.Add(instanceStoreBehavior);

    // Open service host.
    host.Open();

    // Create a client that sends a message to create an instance of the workflow.
    ICountingWorkflow client = ChannelFactory<ICountingWorkflow>.CreateChannel(new BasicHttpBinding(), new EndpointAddress(hostBaseAddress));
    client.start();

    Console.WriteLine("(Press [Enter] at any time to terminate host)");
    Console.ReadLine();
    host.Close();
}

Comentários

O SqlWorkflowInstanceStore executa uma tarefa interna que ativa periodicamente e verifica se existem instâncias executáveis no banco de dados de persistência. Uma instância é executável, se não estiver no estado suspenso ou no estado concluído e atender às seguintes condições:

  • A instância é desbloqueada e tem um timer pendente que expirou.

  • A instância é desbloqueada e seu status é Executando.

  • A instância tem um bloqueio expirado nele.

O Repositório de Instâncias de Fluxo de Trabalho do SQL gera o HasRunnableWorkflowEvent quando encontra uma instância executável no banco de dados e também localiza um host de fluxo de trabalho capaz de carregar a instância em execução no computador.

Quando um host de fluxo de trabalho recebe esse evento, ele executa o TryLoadRunnableWorkflowCommand no repositório de instâncias para carregar a instância na memória.

O tipo da propriedade é TimeSpan e o valor é do formulário "hh:mm:ss". O valor mínimo é "00:00:01" (1 s). Se omitido, o padrão será "00:00:05" (5 s). Esse parâmetro é um parâmetro opcional.

Aplica-se a