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
C:/WINDOWS/system32/drivers/etc HOSTS文件中增加 地址和主机名的对应关系 例如 192.168.1.233 stone
=============这些从晚上找的些资料,我在虚拟机器上(win2003上运行了个XP+sp2)测试IP也可以用。=========
WIN2003 下不用再增加新的配置工作了,但是在XP下如果安装过SP2需要对策略在进行如下配置
不然的话RPC通信的服务程序,在XP下运行失败,错误提示是“拒绝访问”
- 单击“开始”,单击“运行”,键入“gpedit.msc”,然后单击“确定”,打开组策略。
- 打开组策略后,选择“计算机配置->管理模板->系统->远过程调用->用于未验证的RPC客户端的限制”。
- 双击“用于未验证的RPC客户端的限制”,在弹出的右键菜单里选择“属性”。
- 在弹出的“属性”对话框里选择“设置”属性页,选择“已启用”、“要应用的RPC运行时未验证的客户端限制”选择“无”。
- 单击“确定”完成设置。
经测试确定只有XP+SP2会有RPC通信“拒绝访问”的问题,其他Win2K及Win2K以上系统没有此问题。
测试一下:
MSSQL复制如果要采用“即时更新”则需要用到MSDTC,可以用DTCPING来测试MSDTC的环境。DTCPING可以从微软站点下载:
http://www.microsoft.com/downloads/details.aspx?FamilyID=5e325025-4dcd-4658-a549-1d549ac17644&DisplayLang=en
在用的时候要注意一定是两台机器同时运行DTCPING来测试。如果只是单边运行会出现如下提示:
RPC pinging failure
Description:1753-终结点映射器中没有更多的终结点可用。
使得你误以为是RPC没有设置好或者135端口没有开通。
本文介绍如何在C#中使用MSDTC(Microsoft分布式事务协调器)实现分布式事务,确保跨多个资源管理器的操作能够一致地提交或回滚。文中详细解释了通过TransactionScope类的应用来管理事务,并提供了配置MSDTC使其正常工作的步骤。

1025

被折叠的 条评论
为什么被折叠?



