Échec de la validation de la transaction MSDTC interne

Microsoft.SQLServer.2005.Commit_of_internal_MSDTC_transaction_failed_1_5_Rule (Rule)

Knowledge Base article:

Résumé

MS DTC (Microsoft Distributed Transaction Coordinator) peut demander aux participants des transactions, comme les composants COM+ ou une ou plusieurs instances SQL Server, d'exécuter PREPARE dans le cadre du protocole de validation en deux phases (2PC). Si SQL Server répond qu'il est prêt à exécuter COMMIT mais que MS DTC demande d'exécuter ABORT, quelle que soit la raison, cette erreur apparaît sur le serveur ayant émis l'instruction COMMIT. De même, si SQL Server a émis la demande de transaction et demandé à un autre participant d'exécuter PREPARE, mais qu'entre-temps l'un des participants a demandé un ABORT, le serveur ayant émis la demande signalera cette erreur.

Solutions

Ce message indique une activité de validation normale en deux phases. Si vous ne savez pas quelle application ou requête SQL Server appelle MS DTC, vous pouvez utiliser une trace du Générateur de profils SQL pour capturer la commande ayant été abandonnée.

Exemples des motifs de demande de l'instruction ABORT :

Le code de résultat exact renvoyé dans le message varie. Une recherche dans ce code peut fournir des détails supplémentaires sur la cause initiale.

Pour plus d'informations sur MS DTC, consultez « Service MS DTC », « Transactions distribuées », « Architecture des transactions distribuées », « Configuration des serveurs liés » et « Fonctionnement de la mise à jour immédiate » dans la documentation en ligne.

Element properties:

TargetMicrosoft.SQLServer.2005.DBEngine
CategoryEventCollection
EnabledTrue
Event_ID8520
Event Source$Target/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ServiceName$
Alert GenerateTrue
Alert SeverityWarning
Alert PriorityNormal
RemotableTrue
Alert Message
Échec de la validation de la transaction MSDTC interne
{0}
Event LogApplication
CommentMom2005ID='{A7060C45-95ED-4D39-9E2B-1DC2866C0AC4}';MOM2005GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74}

Member Modules:

ID Module Type TypeId RunAs 
_F6DA1507_12AF_11D3_AB21_00A0C98620CE_ DataSource Microsoft.Windows.EventProvider Microsoft.SQLServer.SQLDefaultAccount
GenerateAlert WriteAction System.Health.GenerateAlert Default

Source Code:

<Rule ID="Microsoft.SQLServer.2005.Commit_of_internal_MSDTC_transaction_failed_1_5_Rule" Target="SQL2005Core!Microsoft.SQLServer.2005.DBEngine" Enabled="true" ConfirmDelivery="true" Remotable="true" Comment="Mom2005ID='{A7060C45-95ED-4D39-9E2B-1DC2866C0AC4}';MOM2005GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74}">
<Category>EventCollection</Category>
<DataSources>
<DataSource ID="_F6DA1507_12AF_11D3_AB21_00A0C98620CE_" Comment="{F6DA1507-12AF-11D3-AB21-00A0C98620CE}" TypeID="Windows!Microsoft.Windows.EventProvider" RunAs="SQL!Microsoft.SQLServer.SQLDefaultAccount">
<ComputerName>$Target/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ComputerName>
<LogName>Application</LogName>
<Expression>
<And>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>PublisherName</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>$Target/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ServiceName$</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>EventDisplayNumber</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>8520</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
</And>
</Expression>
</DataSource>
</DataSources>
<WriteActions>
<WriteAction ID="GenerateAlert" TypeID="SystemHealth!System.Health.GenerateAlert">
<Priority>1</Priority>
<Severity>1</Severity>
<AlertMessageId>$MPElement[Name="Microsoft.SQLServer.2005.Commit_of_internal_MSDTC_transaction_failed_1_5_Rule.AlertMessage"]$</AlertMessageId>
<AlertParameters>
<AlertParameter1>$Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue/>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>