SqlWorkflowInstanceStore.RunnableInstancesDetectionPeriod Eigenschaft

Definition

Gibt den Zeitraum an, nach dem der SQL-Workflowinstanzspeicher eine Erkennungsaufgabe ausführt, um nach dem vorherigen Erkennungskreislauf ausführbare oder aktivierbare Workflowinstanzen in der Beibehaltungsdatenbank zu erkennen.

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

Eigenschaftswert

Gibt TimeSpan zurück.

Beispiele

Das folgende Codebeispiel zeigt die Verwendung von RunnableInstancesDetectionPeriod in einem 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();
}

Hinweise

Das SqlWorkflowInstanceStore-Element führt eine interne Aufgabe aus, die in regelmäßigen Abständen aktiviert wird und überprüft, ob ausführbare Instanzen in der Beibehaltungsdatenbank vorhanden sind. Eine Instanz kann ausgeführt werden, wenn sie sich nicht im Zustand angehalten oder abgeschlossen befindet und die folgenden Bedingungen erfüllt:

  • Die Instanz ist nicht gesperrt und weist einen ausstehenden Timer auf, der abgelaufen ist.

  • Die Instanz ist entsperrt, und ihr Status lautet Executing.

  • Die Instanz weist eine abgelaufene Sperre auf.

Der SQL-Workflowinstanzspeicher löst das HasRunnableWorkflowEvent aus, wenn er eine ausführbare Instanz in der Datenbank und einen Workflowhost findet, der die auf dem Computer ausgeführte Instanz laden kann.

Wenn ein Workflowhost dieses Ereignis empfängt, führt er das TryLoadRunnableWorkflowCommand-Element für den Instanzspeicher aus, um die Instanz in den Arbeitsspeicher zu laden.

Der Typ der Eigenschaft ist TimeSpan, und der Wert hat das Format "hh:mm:ss". Der Mindestwert ist "00:00:01" (1 Sekunde). Wenn nicht angegeben, wird standardmäßig "00:00:05" (5 Sekunden) angegeben. Dieser Parameter ist ein optionaler Parameter.

Gilt für: