日期:2008-03-02  浏览次数:20517 次

Aiyiweb.Com提示:c# 分布式事务以及MSDTC.

c# 分布式事务 以及MSDTC

这里处理的是这个问题:
如果一个请求需求执行多个操作:
{
    int iGet=MethodA();
    if(iGet>0){
        MethodB();
    }
}
现有两个方法:
int MethodA(){}
bool MethodB(){}

有可能出现A执行成功,但是B不成功,需求回滚,这就需求MSDTC的系统事务,亦为分布式事务。

其次要功用为使代码块成为事务性代码,在System.Transactions 命名空间下面。使用方法如下:
using (TransactionScope scope = new TransactionScope())
{
    try{
    int iGet=MethodA();
    if(iGet>0){
        MethodB();
    }
    }finally{
    //
    }
    scope.Complete();
}
留意到需求很少的代码,其中执行scope的Complete这个方法的时候执行事务的Commit,如果有异常抛出,事务将回滚。

在多台计算机运转时如果分布式事务无法运转,请确认以下:

1:保证管理工具-》组件管理-》组件服务-》计算机-》我的计算机,右击属性,MSDTC,全部打勾,如何详细控制,后话。

2:保证两台计算机能互相ping通,留意,是ping bios Name ,用的是 netstat -n命令,然后再C:\WINDOWS\SYSTEM32\DRIVERS\ETC\HOST
里面写上例如:

192.168.1.15 s   这样ping s的时候就是192.168.1.15这个计算机了

3:微软提供专门的工具叫做DTCPing,可以测试PRC的形状,同测MSDTC。