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。 |