데이터베이스를 복구하는 동안 오류가 발생했습니다. MSDTC에 연결하여 트랜잭션의 완료 상태를 확인할 수 없습니다.

Microsoft.SQLServer.2008.Error_recovering_database_._Could_not_connect_to_MSDTC_to_check_the_completion_status_of_transaction_1_5_Rule (Rule)

Knowledge Base article:

요약

MS DTC를 사용하여 여러 서버에서 분산 트랜잭션을 관리할 때 연결 손실이 발생하면 분산 트랜잭션은 알 수 없거나 "확실하지 않은" 상태로 남습니다. 중단의 일반적인 원인은 다음과 같습니다.

분산 트랜잭션에 포함된 하나 이상의 컴퓨터에서 위와 같은 상황이 발생하는 경우입니다. 연결이 중단된 후에 MS DTC는 해당 단계에서 진행 중인 모든 트랜잭션을 일관성 없는 상태로 둡니다. "확실하지 않은" 트랜잭션은 SQL Server가 트랜잭션을 커밋하거나 롤백할지 여부를 확인할 수 없고 SQL Server가 MS DTC에서 계속하는 방법을 알려 주도록 요구하기 때문에 이러한 증상을 일으킵니다.

SQL Server를 시작할 때 발생하는 오류 3437, 3414 및 "DTC에 연결하지 못하는 경우"에 대한 자세한 내용은 Microsoft 기술 자료 문서 306366을 참조하십시오.

해결 방법

일관성 없는 분산 트랜잭션을 확인하는 데 사용할 수 있는 여러 가지 방법이 있습니다.

MS DTC 관리 콘솔을 사용하려면 다음과 같이 하십시오.

. 실행 대화 상자에서 "mmc.exe"(인용 부호 제외)를 입력하여 MMC(Microsoft Management Console)를 엽니다.

. MMC의 콘솔 메뉴에서 스냅인 추가/제거를 클릭합니다.

. 스냅인 추가/제거 대화 상자에서 추가를 클릭합니다.

. 독립 실행형 스냅인 추가 대화 상자에서 구성 요소 서비스를 클릭한 다음 추가를 클릭하여 스냅인을 추가합니다.

. 닫기를 클릭

. 스냅인 추가/제거 대화 상자에서 확인을 클릭합니다.

. 구성 요소 서비스의 콘솔 루트에서 구성 요소 서비스를 확장하고, 컴퓨터, 내 컴퓨터를 차례로 가리킨 다음 Distributed Transaction Coordinator를 클릭합니다.

. 트랜잭션 목록을 선택합니다. 세부 정보 창에 트랜잭션이 나타납니다. 트랜잭션을 마우스 오른쪽 단추로 클릭한 다음 해결을 클릭합니다. 이제 커밋, 중단 또는 무시의 세 가지 옵션이 있습니다. 상황에 적합한 옵션을 선택하십시오.

Element properties:

TargetMicrosoft.SQLServer.2008.DBEngine
CategoryEventCollection
EnabledTrue
Event_ID3437
Event Source$Target/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ServiceName$
Alert GenerateTrue
Alert SeverityWarning
Alert PriorityNormal
RemotableTrue
Alert Message
데이터베이스를 복구하는 동안 오류가 발생했습니다. MSDTC에 연결하여 트랜잭션의 완료 상태를 확인할 수 없습니다.
{0}
Event LogApplication
CommentMom2008ID='{6B1C776D-E075-4F73-B9C0-66CEF9024905}';MOM2008GroupID={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.2008.Error_recovering_database_._Could_not_connect_to_MSDTC_to_check_the_completion_status_of_transaction_1_5_Rule" Target="SQL2008Core!Microsoft.SQLServer.2008.DBEngine" Enabled="true" ConfirmDelivery="true" Remotable="true" Comment="Mom2008ID='{6B1C776D-E075-4F73-B9C0-66CEF9024905}';MOM2008GroupID={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>3437</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.2008.Error_recovering_database_._Could_not_connect_to_MSDTC_to_check_the_completion_status_of_transaction_1_5_Rule.AlertMessage"]$</AlertMessageId>
<AlertParameters>
<AlertParameter1>$Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue/>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>