Attributs de transaction ServiceModel
Windows Communication Foundation (WCF) fournit des propriétés sur trois attributs de System.ServiceModel standard qui vous permettent de configurer le comportement des transactions pour un service WCF :
TransactionFlowAttribute
L’attribut TransactionFlowAttribute spécifie la disposition d’une opération de contrat de service à accepter les transactions entrantes provenant d’un client. L'attribut fournit ce contrôle à l'aide de la propriété suivante : les transactions utilisent l'énumération TransactionFlowOption pour spécifier si une transaction entrante est Mandatory, Allowed ou NotAllowed.
C'est le seul attribut qui associe des opérations de service à des interactions externes avec un client. Les attributs décrits dans les sections suivantes concernent l’utilisation de transactions dans l’exécution de l’opération.
ServiceBehaviorAttribute
L'attribut ServiceBehaviorAttribute spécifie le comportement d'exécution interne d'une implémentation de contrat de service. Les propriétés spécifiques aux transactions de cet attribut incluent :
TransactionAutoCompleteOnSessionClose spécifie s'il faut terminer une transaction inachevée à la fermeture de la session. La valeur par défaut de cette propriété est
false
. Si cette propriété a la valeurtrue
, et que la session entrante a été arrêtée normalement et n’a pas été fermée en raison d’erreurs client ou réseau, toute transaction inachevée est correctement exécutée. Sinon, si cette propriété a la valeurfalse
ou si la session n'a pas été correctement fermée, toute transaction inachevée est restaurée à la fermeture de la session. Si cette propriété a la valeurtrue
, le canal entrant doit être basé sur la session.ReleaseServiceInstanceOnTransactionComplete spécifie si l'instance de service sous-jacente est diffusée à la fin de l'exécution d'une transaction. La valeur par défaut de cette propriété est
true
. Le message entrant suivant provoque la création d’une nouvelle instance sous-jacente, en ignorant les états par transaction que l’instance précédente a pu avoir. La diffusion d'une instance de service est une action interne effectuée par le service et n'a aucun impact sur les connexions ou sessions existantes que les clients ont pu établir. Cette fonctionnalité est équivalente à la fonction d’activation juste-à-temps fournie par COM+. Si la propriété a la valeurtrue
, ConcurrencyMode doit être égal à Single. Sinon, le service lève une exception de validation de configuration non valide au démarrage.TransactionIsolationLevel spécifie le niveau d'isolation à utiliser pour les transactions dans le service ; cette propriété prend l'une des valeurs IsolationLevel. Si la propriété de niveau d’isolation locale est autre que Unspecified, le niveau d’isolation d’une transaction entrante doit correspondre au paramètre de cette propriété locale. Sinon, la transaction entrante est rejetée, et une erreur est renvoyée au client. Si TransactionScopeRequired a la valeur
true
, et qu'aucune transaction n'est transmise, cette propriété détermine la valeur IsolationLevel à utiliser pour la transaction créée localement. Si IsolationLevel a la valeur Unspecified, IsolationLevelSerializable est utilisé.TransactionTimeout spécifie le délai dans lequel une nouvelle transaction créée au niveau du service doit s'exécuter. Si au terme de ce délai la transaction n’a pas été exécutée, elle échouera. TimeSpan est utilisé comme délai d’attente TransactionScope pour les opérations dont TransactionScopeRequired a la valeur
true
et pour lesquelles une nouvelle transaction a été créée. Le délai d'attente correspond à la durée maximale autorisée entre la création de la transaction et l'exécution de la phase 1 du protocole de validation en deux phases. La valeur du délai d'attente utilisée est toujours la valeur la plus petite entre la propriété TransactionTimeout et le paramètre de configurationtransactionTimeout
.
OperationBehaviorAttribute
L'attribut OperationBehaviorAttribute spécifie les comportements des méthodes dans l'implémentation de service. Vous pouvez l'utiliser pour indiquer le comportement d'exécution spécifique de l'opération. Les propriétés de cet attribut n’affectent pas la description WSDL (Web Service Description Language) du contrat de service et sont uniquement des éléments du modèle de programmation WCF qui permettent aux développeurs d’implémenter eux-mêmes des fonctionnalités communes.
Cet attribut a les propriétés spécifiques aux transactions suivantes :
TransactionScopeRequired spécifie si une méthode doit s'exécuter dans une étendue de transaction active. Par défaut, il s’agit de
false
. Si l’attribut OperationBehaviorAttribute n’est pas défini pour une méthode, cela implique également que cette méthode ne s’exécutera pas dans une transaction. Si une étendue de transaction n'est pas requise pour une opération, les transactions présentes dans l'en-tête de message ne sont pas activées et restent en tant qu'éléments de IncomingMessageProperties de OperationContext. Si une étendue de transaction est requise pour une opération, la source de la transaction est dérivée de l’un des éléments suivants :Si une transaction est transmise à partir du client, la méthode est exécutée sous une étendue de transaction créée à l'aide de cette transaction distribuée.
Avec un transport de mise en file d’attente, la transaction permettant de supprimer le message de la file d’attente est utilisée. Notez que la transaction utilisée n’est pas une transaction passée, en ce sens qu’elle n’a pas été fournie par l’expéditeur d’origine du message.
Un transport personnalisé peut fournir une transaction à l'aide de
TransportTransactionProperty
.Si aucun des éléments ci-dessus ne fournit de source externe à une transaction, une nouvelle instance Transaction est créée immédiatement avant d'appeler la méthode.
TransactionAutoComplete spécifie si la transaction dans laquelle la méthode s'exécute est automatiquement effectuée si aucune exception non prise en charge n'est levée. Si cette propriété a la valeur
true
, l’infrastructure appelante marque automatiquement la transaction comme étant « exécutée » si la méthode utilisateur retourne une valeur sans lever d’exception. Si cette propriété a la valeurfalse
, la transaction est jointe à l'instance et est uniquement marquée comme étant « exécutée » si le client appelle une méthode suivante marquée avec cette propriété définie à la valeurtrue
, ou si une méthode suivante appelle explicitement SetTransactionComplete. Si aucune de ces conditions n’est vérifiée, la transaction n’est jamais « exécutée », et la tâche contenue n’est pas validée, sauf si la propriété TransactionAutoCompleteOnSessionClose a la valeurtrue
. Si cette propriété a la valeurtrue
, vous devez utiliser un canal avec une session, et InstanceContextMode doit avoir la valeur PerSession.