Freigeben über


SqlWorkflowInstanceStore.InstanceLockedExceptionAction Eigenschaft

Definition

Gibt die Aktion an, die ausgeführt werden soll, wenn der Dauerhaftigkeitsanbieter ein InstanceLockedException-Element abfängt.

public:
 property System::Activities::DurableInstancing::InstanceLockedExceptionAction InstanceLockedExceptionAction { System::Activities::DurableInstancing::InstanceLockedExceptionAction get(); void set(System::Activities::DurableInstancing::InstanceLockedExceptionAction value); };
public System.Activities.DurableInstancing.InstanceLockedExceptionAction InstanceLockedExceptionAction { get; set; }
member this.InstanceLockedExceptionAction : System.Activities.DurableInstancing.InstanceLockedExceptionAction with get, set
Public Property InstanceLockedExceptionAction As InstanceLockedExceptionAction

Eigenschaftswert

Die Aktion, die ausgeführt werden soll, wenn der Dauerhaftigkeitsanbieter eine InstanceLockedException abfängt.

Beispiele

Das folgende Codebeispiel zeigt die Verwendung von InstanceLockedExceptionAction 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

Gibt an, welche Aktion ein Diensthost ausführen soll, wenn eine Workflowdienstinstanz auf eine InstanceLockedException trifft. Der Diensthost empfängt ein InstanceLockedException-Element, wenn er versucht, eine Instanz zu sperren, die bereits von einem anderen Besitzer gesperrt wurde. Die möglichen Werte werden in der folgenden Tabelle aufgeführt:

  • Keine. Der Diensthost versucht nicht, die Instanz zu sperren und übergibt die InstanceLockedException an den Aufrufer.

  • BasicRetry. Der Diensthost versucht erneut, die Instanz mit einem linearen Wiederholungsintervall zu sperren, und übergibt am Ende der Sequenz die Ausnahme an den Aufrufer.

  • AggressiveRetry. Der Diensthost versucht erneut, die Instanz mit einer exponentiell zunehmenden Verzögerung zu sperren, und übergibt am Ende der Sequenz die InstanceLockedException an den Aufrufer. Die Intervalle sind zu Anfang kurz, um zu versuchen, die Sperre so schnell wie möglich vorzunehmen, und werden mit jedem fehlgeschlagenen Versuch länger.

Gilt für: