将不确定变为确定~transactionscope何时提升为分布式事务?
生活随笔
收集整理的這篇文章主要介紹了
将不确定变为确定~transactionscope何时提升为分布式事务?
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
相關(guān)文章
將不確定變?yōu)榇_定~transactionscope何時提升為分布式事務(wù)
將不確定變?yōu)榇_定~transactionscope何時提升為分布式事務(wù)~續(xù)??????
將不確定變?yōu)榇_定~transactionscope何時提升為分布式事務(wù)~再續(xù)(避免引起不必要的MSDTC)
?
?????? 對于frameworks的TransactionScope大家應(yīng)該都很熟悉了,它是一個分布式事務(wù)的語句塊,被包含起來的語句可以一起被提交,當出現(xiàn)異常后,統(tǒng)一進行回滾,這一切都是托管的。
當WEB服務(wù)器沒有開啟MSDTC服務(wù)時,會出現(xiàn)這個提示:
對于servers.msc中的MSDTC服務(wù),它經(jīng)常性的被掛掉
注意一下:如果你的msdtc服務(wù)掛了,當下一次WWW程序需要用到它時,它會自由重啟。
而對于你的事務(wù)塊,如果這個MSDTC服務(wù)被掛了后,如果你的事務(wù)塊中包含“跨庫”操作,它將會被自動提升到MSDTC分布式事務(wù),
這時你整個代碼塊將會中斷,并拋出你的異常!
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 /// 靜態(tài)上下文 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 }這時,你的程序由于服務(wù)器MSDTC的問題,整個流程被“走不通”,其時這是正常的,事務(wù)的作用就是為了保持“數(shù)據(jù)的完整性”,如果你把語句塊寫在同一事務(wù)中,那說明他們應(yīng)該是同進同退的,這是一個理論的問題。
而我在之前看過老趙寫過一個博文提到這個類似問題,看數(shù)據(jù)上下文的共享性會影響到事務(wù)被提升到MSTDC,我的測試告訴我,沒有實現(xiàn)這個結(jié)果,這里希望老趙給出一個答案吧,呵呵!在這里先謝謝趙老大了!
本文轉(zhuǎn)自博客園張占嶺(倉儲大叔)的博客,原文鏈接:將不確定變?yōu)榇_定~transactionscope何時提升為分布式事務(wù)?,如需轉(zhuǎn)載請自行聯(lián)系原博主。總結(jié)
以上是生活随笔為你收集整理的将不确定变为确定~transactionscope何时提升为分布式事务?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 快速生成树(RSTP)和传统生成树(ST
- 下一篇: Web自适应布局你需要知道的所有事儿