服务器配置:in-doubt xact resolution
适用于:SQL Server Azure SQL 托管实例 Azure 虚拟机上的 SQL Server
使用 in-doubt xact resolution
选项可以控制 Microsoft 分布式事务处理协调器 (MS DTC) 无法解决的默认事务结果。 事务无法解决可能与 MS DTC 停止工作或恢复时的未知事务结果有关。
下表列出了解决有疑问的事务可能出现的结果值。
结果值 | 说明 |
---|---|
0 |
没有假设。 如果 MS DTC 无法解决任何有疑问的事务,恢复就会失败。 |
1 |
假设提交。 假设已提交任何 MS DTC 有疑问的事务。 |
2 |
假设中止。 假设已中止任何 MS DTC 有疑问的事务。 |
若要尽可能减少扩展的停止工作时间,管理员可以选择将此选项配置为假设提交或假设中止,如以下示例所示。
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'in-doubt xact resolution', 2; -- presume abort
GO
RECONFIGURE;
GO
sp_configure 'show advanced options', 0;
GO
RECONFIGURE;
GO
另外,管理员也可能希望保留默认值(没有假设)并允许恢复失败,以便了解 DTC 故障,如以下示例所示。
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'in-doubt xact resolution', 1; -- presume commit
GO
RECONFIGURE
GO
ALTER DATABASE pubs SET ONLINE -- run recovery again
GO
sp_configure 'in-doubt xact resolution', 0 -- back to no assumptions
GO
sp_configure 'show advanced options', 0
GO
RECONFIGURE
GO
in-doubt xact resolution
选项是一个高级选项。 如果使用 sp_configure
系统存储过程来更改该设置,则只有在 show advanced options
设置为 1
时才能更改 in-doubt xact resolution
。 该设置将立即生效,无需重新启动服务器。
注意
在任何分布式事务所涉及的所有 SQL Server 实例中,使此选项的配置始终保持一致,有助于避免数据的不一致。