日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

将不确定变为确定~transactionscope何时提升为分布式事务?

發布時間:2025/3/8 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 将不确定变为确定~transactionscope何时提升为分布式事务? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

相關文章

將不確定變為確定~transactionscope何時提升為分布式事務

將不確定變為確定~transactionscope何時提升為分布式事務~續??????

將不確定變為確定~transactionscope何時提升為分布式事務~再續(避免引起不必要的MSDTC)


?

?????? 對于frameworks的TransactionScope大家應該都很熟悉了,它是一個分布式事務的語句塊,被包含起來的語句可以一起被提交,當出現異常后,統一進行回滾,這一切都是托管的。

當WEB服務器沒有開啟MSDTC服務時,會出現這個提示:

對于servers.msc中的MSDTC服務,它經常性的被掛掉

注意一下:如果你的msdtc服務掛了,當下一次WWW程序需要用到它時,它會自由重啟。

而對于你的事務塊,如果這個MSDTC服務被掛了后,如果你的事務塊中包含“跨庫”操作,它將會被自動提升到MSDTC分布式事務,

這時你整個代碼塊將會中斷,并拋出你的異常!

1 public abstract class DAL<T> : IDAL<T> where T : class 2 { 3 4 public DAL(DbContext db) 5 { 6 DB = db; 7 } 8 9 10 #region Properies 11 /// <summary> 12 /// 靜態上下文 13 /// </summary> 14 // protected readonly static DbContext DB = new Entity.testEntities(); 15 16 /// <summary> 17 /// 實例上下文 18 /// </summary> 19 protected DbContext DB; 20 21 #endregion 1      using (TransactionScope trans = new TransactionScope()) 2 { 3 try 4 { 5 base.Insert(entity); 6 entity.User_Profile.ID = entity.ID; 7 user_ProfileDAL.Insert(entity.User_Profile); 8 loginLogsDAL.Insert(new Entity.TestMSDTC.LoginLogs //跨庫操作 9 { 10 ID = entity.ID, 11 LoginName = entity.Name, 12 }); 13 trans.Complete(); 14 } 15 catch (Exception) 16 { 17 18 throw; 19 } 20 finally 21 { 22 trans.Dispose(); 23 } 24 }

這時,你的程序由于服務器MSDTC的問題,整個流程被“走不通”,其時這是正常的,事務的作用就是為了保持“數據的完整性”,如果你把語句塊寫在同一事務中,那說明他們應該是同進同退的,這是一個理論的問題。

而我在之前看過老趙寫過一個博文提到這個類似問題,看數據上下文的共享性會影響到事務被提升到MSTDC,我的測試告訴我,沒有實現這個結果,這里希望老趙給出一個答案吧,呵呵!在這里先謝謝趙老大了!

本文轉自博客園張占嶺(倉儲大叔)的博客,原文鏈接:將不確定變為確定~transactionscope何時提升為分布式事務?,如需轉載請自行聯系原博主。

總結

以上是生活随笔為你收集整理的将不确定变为确定~transactionscope何时提升为分布式事务?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。