日期:2013-11-26  浏览次数:20941 次

(转自saucer)
在企业开发里,经常遇到的一个问题是需要做Distributed Transactions。一般推荐的做法是做成ServicedComponent,参考

Transaction Control
Writing Serviced Components

这种做法有几个问题,该组件以及所依赖组件必须是Strong-Named的,在通常的情形下(譬如Web Application里),我们需要手动注册组件。但这样,如果我们改动组件的话,需要停止服务,注销组件,然后重新注册组件。另外,这Transaction是declarative和automatic的,无法用编码精确控制 Transaction,而且declaration是在类的级别上的,无法在方法层次做 Transaction。其原因是,ServicedComponent是基于早期COM+的服务架构之上的,Transactional Context是与Object(对象)密切结合在一起的。

但在几年前随XP推出的COM+ 1.5 (Windows 2003服务器也有支持)里, Transactional Context可以独立于Object(对象)之外,极大地简化了Transactional programming。下面这篇2002年MSDN杂志上由COM+专家Tim Ewald介绍了相关的API (CoEnterServiceDomain/CoLeaveServiceDomain),并且提供了C# wrapper 。

Discover Powerful Low-Level Programming in Windows XP with New COM+ APIs

在.NET 1.1里,同样的功能是由2个类,System.EnterpriseServices.ServiceDomain与System.EnterpriseServices.ServiceConfig,来实现的。

这里是Don Box去年7月12日的blog里的例子,

ServiceConfig config = newServiceConfig();
config.Transaction = TransactionOption.Required;
ServiceDomain.Enter(config);
MyTxCode();
ServiceDomain.Leave();

在.NET 2.0里,根据Don,你可以这么做

using (TransactionScope scope = newTransactionScope())
{
MyTxCode();
scope.Consistent = true;
}


也请参考

Using distributed transactions in .Net 1.x without deriving from ServicedComponent