SqlWorkflowInstanceStore.RunnableInstancesDetectionPeriod Propriété

Définition

Spécifie la période de temps au-delà de laquelle le magasin d’instances de flux de travail SQL exécute une tâche de détection pour détecter toutes les instances de flux de travail exécutables ou activables dans la base de données de persistance à l’issue du cycle de détection précédent.

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

Valeur de propriété

Retourne TimeSpan.

Exemples

L'exemple de code suivant montre comment utiliser RunnableInstancesDetectionPeriod dans 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();
}

Remarques

L’objet SqlWorkflowInstanceStore exécute une tâche interne qui se réveille régulièrement et vérifie si toutes les instances exécutables existent dans la base de données de persistance. Une instance est exécutable, si elle n’est pas à l’état suspendu ou terminé et qu’elle remplit les conditions suivantes :

  • L'instance est déverrouillée et a un minuteur en attente qui a expiré.

  • L’instance est déverrouillée et son état est Exécution.

  • L'instance a un verrou périmé.

Le magasin d'instances de flux de travail SQL déclenche l'événement HasRunnableWorkflowEvent lorsqu'il recherche une instance exécutable dans la base de données, ainsi qu'un hôte de flux de travail capable de charger l'instance en cours d'exécution sur l'ordinateur.

Lorsqu'un hôte de flux de travail reçoit cet événement, il exécute la commande TryLoadRunnableWorkflowCommand sur le magasin d'instances pour charger l'instance en mémoire.

Le type de la propriété est TimeSpan et la valeur est de la forme « hh:mm:ss ». La valeur minimale est « 00:00:01 » (1 seconde). En cas d’omission, la valeur par défaut est « 00:00:05 » (5 secondes). Ce paramètre est optionnel.

S’applique à