c# 分散式交易以及MSDTC

來源:互聯網
上載者:User
# 分散式交易 以及MSDTC。這裡解決的是這個問題:

# 分散式交易 以及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。



相關文章

Cloud Intelligence Leading the Digital Future

Alibaba Cloud ACtivate Online Conference, Nov. 20th & 21st, 2019 (UTC+08)

Register Now >

11.11 Big Sale for Cloud

Get Unbeatable Offers with up to 90% Off,Oct.24-Nov.13 (UTC+8)

Get It Now >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

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

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