Compartir vía


<sqlWorkflowInstanceStore>

Un comportamiento del servicio que permite configurar la característica SqlWorkflowInstanceStore, que admite la conservación de la información de estado de las instancias del servicio de flujo de trabajo en una base de datos SQL Server 2005 o SQL Server 2008. Para obtener más información sobre esta característica, consulta Almacén de instancias de flujo de trabajo de SQL.

<configuración>
   <system.ServiceModel>
     <behaviors>
       <serviceBehaviors>
         <comportamiento>
           <sqlWorkflowInstanceStore>

Sintaxis

<behaviors>
  <serviceBehaviors>
    <behavior name="String">
      <sqlWorkflowInstanceStore connectionStringName="String"
                                hostLockRenewalPeriod="TimeSpan"
                                instanceCompletionAction="DeleteNothing/DeleteAll"
                                instanceEncodingAction="None/GZip"
                                instanceLockedExceptionAction="NoRetry/BasicRetry/AggressiveRetry"
                                runnableInstancesDetectionPeriod="TimeSpan" />
    </behavior>
  </serviceBehaviors>
</behaviors>  

Atributos y elementos

En las siguientes secciones se describen los atributos, los elementos secundarios y los elementos primarios.

Atributos

Atributo Descripción
connectionString Una cadena que contiene una cadena de conexión que usa para conectarse a una base de datos de persistencia subyacente.
connectionStringName Cadena que contiene una cadena de conexión con nombre en el servidor de bases de datos. Un ejemplo de una cadena de conexión con nombre es «DefaultConnectionString».
hostLockRenewalPeriod Valor de Timespan que especifica el período de tiempo en el que el host debe renovar el bloqueo en una instancia. Si el host no renueva el bloqueo en el período de tiempo especificado, la instancia se desbloquea y se puede escoger a por otro host.

Descargar un flujo de trabajo implica que también se conserva. Si este atributo se pone a cero, la instancia de flujo de trabajo se conserva y se descarga de inmediato en cuanto el flujo de trabajo se vuelve inactivo. Al establecer este atributo en TimeSpan.MaxValue, se deshabilita de forma eficaz la operación de descarga. Las instancias de flujo de trabajo inactivas nunca se descargan.
instanceCompletionAction Un valor que especifica si los datos de la instancia de flujo de trabajo se mantienen en el almacén de persistencia después de que la instancia de flujo de trabajo se complete o si se ha eliminado en ese punto. Este valor es del tipo InstanceCompletionAction.

Las acciones enumeradas consisten en eliminar los datos de instancia del almacén de persistencia o en no eliminar los datos de instancia del almacén de persistencia cuando la instancia haya completado su operación.

Mantener las instancias una vez completadas provoca que la base de datos de persistencia crezca rápidamente y esto afecta al rendimiento de la base de datos. Debería configurar una directiva de purga de base de datos para eliminar estos registros de forma periódica para asegurarse de que el rendimiento de la base de datos está en el nivel que satisface sus requisitos de rendimiento.
instanceEncodingOption Un valor opcional que especifica si la información de estado de la instancia se comprime utilizando el algoritmo Gzip antes de que la información se guarde en el almacén de persistencia. Este valor es del tipo InstanceEncodingOption. Los valores posibles para esta propiedad son None, que no especifica la compresión, y GZip, que especifica que los datos de instancia se comprimen y utilizan el algoritmo gzip.
instanceLockedExceptionAction Un valor que especifica la acción que se produce en respuesta a una excepción que se produce cuando el host intenta bloquear una instancia porque otro host bloquea actualmente la instancia. Este valor es del tipo InstanceLockedExceptionAction.

Las opciones permitidas para este campo son: Ninguno, intento básico y reintento agresivo. El valor predeterminado es Ninguno. La siguiente lista proporciona las descripciones de estas tres opciones:

- Ninguno. El host del servicio no intenta bloquear la instancia y pasa el objeto InstanceLockedException al autor de la llamada.
- Reintento básico. El host del servicio vuelve a intentar bloquear la instancia con un intervalo de reintento lineal y pasa la excepción al autor de la llamada al final de la secuencia.
- Reintento agresivo. El host del servicio vuelve a intentar bloquear la instancia con un retraso en aumento exponencial y pasa el objeto InstanceLockedException al autor de llamada al final de la secuencia.
runnableInstancesDetectionPeriod

Elementos secundarios

Ninguno.

Elementos primarios

Elemento Descripción
<comportamiento> de <serviceBehaviors> Especifica un elemento de comportamiento.

Consulte también