distributedcom|Distributed Transactions

更新时间:2014-07-05    来源:Action    手机版     字体:

【www.bbyears.com--Action】

(转自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

本文来源:http://www.bbyears.com/flash/7574.html

热门标签

更多>>

本类排行