SqlWorkflowInstanceStore.RunnableInstancesDetectionPeriod Eigenschaft
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Gibt den Zeitraum an, nach dem der SQL-Workflowinstanzspeicher eine Erkennungsaufgabe ausführt, um alle ausgeführten oder aktivierbaren Workflowinstanzen in der Persistenzdatenbank nach dem vorherigen Erkennungszyklus 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 veranschaulicht 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
Die SqlWorkflowInstanceStore Ausführung einer internen Aufgabe, die regelmäßig aktiviert wird und überprüft, ob in der Persistenzdatenbank runnable Instanzen vorhanden sind. Eine Instanz kann ausgeführt werden, wenn sie sich nicht im angehaltenen Zustand oder im abgeschlossenen Zustand befindet und die folgenden Bedingungen erfüllt:
Die Instanz ist entsperrt und verfügt über einen ausstehenden Timer, der abgelaufen ist.
Die Instanz ist entsperrt und ihr Status ist auf Ausführung.
Die Instanz weist eine abgelaufene Sperre auf.
Der SQL-Workflowinstanzspeicher löst den HasRunnableWorkflowEvent Fall aus, wenn er eine ausgeführte Instanz in der Datenbank findet und auch einen Workflowhost findet, der die Instanz laden kann, die auf dem Computer ausgeführt wird.
Wenn ein Workflowhost dieses Ereignis empfängt, wird er für den TryLoadRunnableWorkflowCommand Instanzspeicher ausgeführt, um die Instanz in den Speicher zu laden.
Der Typ der Eigenschaft ist TimeSpan und der Wert ist das Format "hh:mm:ss". Der Mindestwert ist "00:00:01" (1 Sek.). Wenn nicht angegeben, wird standardmäßig "00:00:05" (5 Sek.) verwendet. Dieser Parameter ist ein optionaler Parameter.