群集中的MS DTC分布式事务协调器

本文详细介绍了SQL Server群集环境下MSDTC的安装步骤和故障转移方式,包括如何为DTC分配IP、使用独立共享磁盘以避免数据干扰、以及群集中DTC故障时的转移机制。此外,还对比了Windows 2003及以前版本与Windows Server 2008中MSDTC的不同实现方式,强调了后者提供的主动/主动支持和性能优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MS DTC在大多数SQL 服务器下都需要安装,若只是安装数据库引擎或Analysis 服务可不安装DTC。如果后需要使用分布式事务,则可在SQL Server群集安装完成后再安装DTC。

一、群集MS DTC安装

与正常添加群集服务类似在故障转移管理器,右击服务和应用程序à配置服务和应用程序。

 

需要为DTC分配IP。如下图所示,此为跨子网群集,因此要在配置两个虚拟IP。

在安装DTC的时候最好的做法是使用独立的共享磁盘,以免DTC数据影响数据库存储磁盘数据的使用。如下图所示

二、MS DTC故障转移方式

与SQL Server服务故障转移类似,当群集指定某个节点的DTC失败,则将通过仲裁,将DTC服务转移到其他节点上。IP和磁盘资源也将重新绑定到新节点上。
在新的节点上,重启的DTC将读取共享磁盘上DTC的日志文件,来确定未处理的事务和最近解决的事务。如下图所示,DTC在B节点上运作,若B节点失败,服务器将转移到A节点上,DTC事务管理器将持续读取共享磁盘DTC Log,重新运作。

 

三、群集MSDTC与本地MSDTC

Windows 2003及以前版本仅支持在整个Windows 群集上创建一个MSDTC实例,但一个MSDTC有如下缺点:

  1. 隔离性不好,因为所有应用程序都共享单独的DTC
    由于所有的应用程序或者服务都共享同一个DTC,当因为某个应用程序故障导致DTC不可用时候,其它应用程序和服务也都无法访问DTC
  2. 性能不好
    性能可能不够理想,比如当DTC需要处理一个不在本节点上一个应用程序的分布式事物时候,DTC延迟时间可能超过应用程序容忍的最大时间,导致服务超时或者故障转移.

Windows Server 2008故障转移群集可安装多站点DTC,提供了主动/主动的支持,有如下优点:

  1. 一个群集中的应用程序失败不会影响其他群集中的应用程序.
  2. 性能延迟问题减轻

    每个节点可以有一个非常接近的DTC资源.减轻延迟的影响.

本地MSDTC

群集的所有节点可以独立安装本地DTC,如下图所示群集组Myclustergrp1有自己的默认DTC和本地DTC.

Multiple MSDTC

群集组还可以安装多个DTC实例,可以设置每个群集应用程序对应各自的DTC资源.如下图所示,一般情况下若群集应用程序有自己的DTC资源,则使用该DTC进行分发事务.若没有,则会使用群集资源里的其他DTC,若群集组里也没有,就会使用本地DTC.

转载于:https://www.cnblogs.com/chhuang/p/4193967.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值