zoukankan      html  css  js  c++  java
  • 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。
  • 相关阅读:
    向SDE库中写入栅格和矢量数据
    datagridview使用方法
    GP Statics
    GP tool , Resample, Mask, Clip
    好的影像库网站
    文件及文件夹相关操作
    使用GeoProcessing进行批处理的编程方式(粗粒度的编程)
    git clear local branches All In One
    node js module exports multiple variables All In One
    推荐的 iPad 绘画入门教程资源 All In One
  • 原文地址:https://www.cnblogs.com/chenbg2001/p/1762247.html
Copyright © 2011-2022 走看看