c# 分散式交易以及MSDTC

來源:互聯網
上載者:User

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。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.