SqlWorkflowInstanceStore.InstanceLockedExceptionAction Propiedad
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Especifica la acción que se va a realizar cuando el proveedor de persistencia detecta un 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
Valor de propiedad
La acción que se debe realizar cuando el proveedor de persistencia detecta un InstanceLockedException
Ejemplos
En el ejemplo de código siguiente se muestra el uso de InstanceLockedExceptionAction 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();
}
Comentarios
Especifique qué acción debe realizar un host de servicio cuando una instancia de servicio de flujo de trabajo experimenta un InstanceLockedException. El host de servicio recibe un InstanceLockedException cuando intenta bloquear una instancia que ya está bloqueada por otro propietario. Los valores posibles están en la lista siguiente:
Ninguno. El host del servicio no intenta bloquear la instancia y pasa al InstanceLockedException autor de la llamada.
BasicRetry. El host de servicio vuelve a adjuntar para bloquear la instancia con un intervalo de reintento lineal y pasa la excepción al autor de la llamada al final de la secuencia.
AggressiveRetry. El host de servicio vuelve a adjuntar para bloquear la instancia con un retraso exponencialmente creciente y pasa al InstanceLockedException autor de la llamada al final de la secuencia. Los intervalos son cortos al principio en un intento de adquirir el bloqueo lo más rápido posible y los intervalos se vuelven más grandes con cada intento incorrecto.