当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > c# 分布式事务以及MSDTC

ASP.NET
一个无刷新效果定时自动更新页面的例子
ASP.NET2.0的控件状态和视图状态探讨
用好ASP.NET 2.0的URL映射
详解:如何在.NET中访问MySQL数据库?
如何实现Asp与Asp.Net共享Session
利用.net的强大功能发送email
.NET中加密与解密QueryString的方法
Asp.net生成htm静态文件的两种途径
C#定时器的使用
从XML文件中读取数据绑定到DropDownList
ASP.NET 2.0 里输出文本格式流
用.net动态创建类的实例
.Net下的MSMQ的同步异步调用
ASP.NET 2.0实现防止同一用户同时登陆
asp.NET自定义服务器控件内部细节
组合.NET数据控件构建强大用户接口
用ASP.NET 2.0 FormView控件控制显示
菜鸟也学习ASP.NET如何读取数据库内容
教你简单方便获取Web设计的免费资源
专家详解:复杂表达式的执行步骤

ASP.NET 中的 c# 分布式事务以及MSDTC


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 194 ::
收藏到网摘: n/a

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。