Distributed Transactions
发表于:2007-06-30来源:作者:点击数:
标签:
(转自saucer) 在企业 开发 里,经常遇到的一个问题是需要做Distributed Transactions。一般推荐的做法是做成ServicedComponent,参考 Transaction Control Writing Serviced Components 这种做法有几个问题,该组件以及所依赖组件必须是Strong-Named的,在
(转自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.ltesting.net