SqlWorkflowInstanceStore.InstanceLockedExceptionAction Egenskap
Definition
Viktigt
En del information gäller för förhandsversionen av en produkt och kan komma att ändras avsevärt innan produkten blir allmänt tillgänglig. Microsoft lämnar inga garantier, uttryckliga eller underförstådda, avseende informationen som visas här.
Anger vilken åtgärd som ska vidtas när beständighetsprovidern fångar upp en InstanceLockedException.
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
Egenskapsvärde
Den åtgärd som ska vidtas när beständighetsleverantören får en InstanceLockedException
Exempel
Följande kodexempel visar hur du använder InstanceLockedExceptionAction i en 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();
}
Kommentarer
Ange vilken åtgärd en tjänstvärd ska vidta när en instans av arbetsflödestjänsten upplever en InstanceLockedException. Tjänstvärden får en InstanceLockedException när den försöker låsa en instans som redan är låst av en annan ägare. Möjliga värden finns i följande lista:
Ingen. Tjänstvärden försöker inte låsa instansen och skickar den InstanceLockedException till anroparen.
BasicRetry. Tjänstvärden försöker igen för att låsa instansen med ett linjärt återförsöksintervall och skickar undantaget till anroparen i slutet av sekvensen.
AggressiveRetry. Tjänstvärden försöker låsa instansen igen med en exponentiellt ökande fördröjning och skickar InstanceLockedException den till anroparen i slutet av sekvensen. Intervallen är korta i början i ett försök att hämta låset så snabbt som möjligt och intervallen blir större vid varje misslyckat försök.