SqlWorkflowInstanceStore.RunnableInstancesDetectionPeriod Propiedad

Definición

Especifica el período de tiempo después del cual el Almacén de instancias de flujo de trabajo de SQL ejecuta una tarea de detección para detectar cualquier instancia de flujo de trabajo ejecutable o activable en la base de datos de persistencia después del ciclo de detección 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 de propiedad

Devuelve TimeSpan.

Ejemplos

En el ejemplo de código siguiente se muestra el uso de RunnableInstancesDetectionPeriod en un 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();
}

Comentarios

SqlWorkflowInstanceStore ejecuta una tarea interna que se activa periódicamente y comprueba si existen instancias ejecutables en la base de datos de persistencia. Se puede ejecutar una instancia, si no está en estado suspendido o el estado completado y cumple las condiciones siguientes:

  • La instancia está desbloqueada y tiene un temporizador pendiente que ha expirado.

  • La instancia está desbloqueada y su estado es En ejecución.

  • La instancia tiene un bloqueo expirado en ella.

El almacén de instancias de flujo de trabajo de SQL genera cuando HasRunnableWorkflowEvent encuentra una instancia ejecutable en la base de datos y también encuentra un host de flujo de trabajo capaz de cargar la instancia que se ejecuta en el equipo.

Cuando un host de flujo de trabajo recibe este evento, ejecuta en TryLoadRunnableWorkflowCommand el almacén de instancias para cargar la instancia en la memoria.

El tipo de la propiedad es TimeSpan y el valor es de la forma "hh:mm:ss". El valor mínimo es "00:00:01" (1 s). Si se omite, el valor predeterminado es "00:00:05" (5 segundos). Este parámetro es un parámetro opcional.

Se aplica a