事务管理器
本文关键字:管理器 事务管理 事务 | 更新日期: 2023-09-27 18:04:11
如果我使用。net System.Transactions.TransactionScope类处理Oracle数据库中跨多个表的事务,哪个将使用LTM[轻量级事务管理器]或MSDTC[微软分布式事务协调器]?
是否有任何规则或策略来决定何时使用哪一个?请建议。此外,想知道何时使用两阶段提交?它是否仅用于跨多个数据库的分布式事务?
谢谢。
基本的经验法则是,事务资源(例如DB、队列、消息传递引擎、文件系统等)将选择它所知道的最便宜和最轻的事务协调器(Transaction Coordinator, TC)。
MSDTC(或第三方替代方案)通常只在事务跨越多个物理盒(这需要分布式TC - DTC)或它们跨越多个资源(其中一个只理解MSDTC)时调用。
对于完全在特定服务器应用程序内的事务,他们可能会使用自己的内部TC或使用他们运行的平台上最便宜的TC。
Vista/Server2008引入了内核事务监视器(KTM),它提供了一个非常快的盒装TC。系统。如果可用,事务将使用KTM,但如果没有(例如在XP/Server2003上运行时),将调用MSDTC。
KTM允许,例如,更新数据库,一些(NTFS)文件和MSMQ队列,它们都驻留在同一个物理机器上,而不需要(更昂贵的)分布式事务。
唉,一些较旧的软件不知道KTM,当在超出其本地作用域的事务中登记时,可能会调用MSDTC。