溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么掌握ADO.NET資源管理器原理機(jī)制

發(fā)布時(shí)間:2021-12-03 17:02:49 來(lái)源:億速云 閱讀:124 作者:iii 欄目:編程語(yǔ)言

這篇文章主要介紹“怎么掌握ADO.NET資源管理器原理機(jī)制”,在日常操作中,相信很多人在怎么掌握ADO.NET資源管理器原理機(jī)制問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”怎么掌握ADO.NET資源管理器原理機(jī)制”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

事務(wù)中使用的每個(gè)資源都由資源管理器進(jìn)行管理,而后者的操作則由事務(wù)管理器進(jìn)行協(xié)調(diào)。資源管理器與事務(wù)管理器協(xié)調(diào)工作,為應(yīng)用程序提供了原子性和隔離性的保證。例如,Microsoft SQL Server、持久消息隊(duì)列、內(nèi)存中的哈希表都是ADO.NET資源管理器。

ADO.NET資源管理器可管理持久或可變數(shù)據(jù)。資源管理器的持久性(反之為可變性)是指資源管理器是否支持故障恢復(fù)。如果資源管理器支持故障恢復(fù),則它會(huì)在第 1 階段(準(zhǔn)備階段)將數(shù)據(jù)保存到持久存儲(chǔ)區(qū)中;這樣,一旦資源管理器出現(xiàn)故障,它就可在恢復(fù)時(shí)在事務(wù)中重新登記,并根據(jù)從 TM 接收到的通知執(zhí)行適當(dāng)?shù)牟僮?。通常,可變資源管理器管理如內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)之類的可變資源(如內(nèi)存中的事務(wù)處理哈希表),而持久資源管理器則管理具有更持久的后備存儲(chǔ)區(qū)的資源(例如,其后備存儲(chǔ)區(qū)為磁盤的數(shù)據(jù)庫(kù))。

資源若要參與事務(wù),它必須在事務(wù)中進(jìn)行登記。Transaction 類定義了一組提供此功能的方法,這些方法的名稱以 Enlist 開(kāi)頭。不同的 Enlist 方法對(duì)應(yīng)于資源管理器可能具有的不同登記類型。具體來(lái)說(shuō),EnlistVolatile 方法用于登記可變資源,而 EnlistDurable 方法則用于登記持久資源。為了簡(jiǎn)單起見(jiàn),在根據(jù)資源的持久性支持決定是使用 EnlistDurable 還是 EnlistVolatile 方法后,應(yīng)為資源管理器實(shí)現(xiàn) IEnlistmentNotification 接口,從而將資源登記為參與兩階段提交 (2PC)。有關(guān) 2PC 的更多信息,請(qǐng)參見(jiàn)在單階段和多階段中提交事務(wù)。

通過(guò)登記,資源管理器可確保在事務(wù)提交或中止時(shí)能夠從事務(wù)管理器獲取回調(diào)。每個(gè)登記都有一個(gè) IEnlistmentNotification 實(shí)例。通常情況下,在每個(gè)事務(wù)中只執(zhí)行一次登記,但資源管理器可選擇在同一事務(wù)中執(zhí)行多次登記。

登記后,ADO.NET資源管理器會(huì)對(duì)事務(wù)的請(qǐng)求做出響應(yīng)。持久資源管理器存儲(chǔ)了足夠的信息,可允許在它所管理的資源上撤消或重做事務(wù)的工作。可以使用許多方法來(lái)實(shí)現(xiàn)此目的;最常采用的兩種方法是保存數(shù)據(jù)版本和保存更改日志。

當(dāng)應(yīng)用程序提交事務(wù)時(shí),事務(wù)管理器會(huì)啟動(dòng)兩階段提交協(xié)議。事務(wù)管理器先向每個(gè)已登記的資源管理器詢問(wèn)它是否已準(zhǔn)備好提交事務(wù)。資源管理器必須準(zhǔn)備好提交,即它自身準(zhǔn)備好提交或中止事務(wù)。

在準(zhǔn)備階段,持久資源管理器會(huì)將舊數(shù)據(jù)和新數(shù)據(jù)記錄到固定存儲(chǔ)區(qū)中,以便即使系統(tǒng)出現(xiàn)故障,資源管理器也可恢復(fù)數(shù)據(jù)。如果資源管理器準(zhǔn)備就緒,就會(huì)向事務(wù)管理器通知有關(guān)它是提交還是中止事務(wù)的投票。如果有任何資源管理器報(bào)告準(zhǔn)備失敗,則事務(wù)管理器會(huì)將回滾命令發(fā)送給每個(gè)資源管理器,并向應(yīng)用程序指出提交失敗。

在準(zhǔn)備就緒后,資源管理器必須等待,直到它在第 2 階段中從事務(wù)管理器獲取提交或中止回調(diào)為止。通常,整個(gè)準(zhǔn)備和提交協(xié)議不到一秒即可完成。如果發(fā)生系統(tǒng)或通信故障,則提交或中止通知可能無(wú)法在幾分鐘或幾小時(shí)內(nèi)送達(dá)。在此期間,資源管理器將無(wú)法確定事務(wù)的結(jié)果,即不知道事務(wù)是已提交還是已中止。當(dāng)資源管理器不確定事務(wù)狀態(tài)時(shí),它會(huì)通過(guò)使事務(wù)處于鎖定狀態(tài)來(lái)保留已修改的數(shù)據(jù),從而將這些更改與任何其他事務(wù)隔離開(kāi)。

如果資源管理器發(fā)生故障,則除了在發(fā)生故障之前已準(zhǔn)備或提交的事務(wù)之外,其余所有已登記事務(wù)都將中止。當(dāng)持久資源管理器重新啟動(dòng)時(shí),它會(huì)通過(guò)檢索在準(zhǔn)備階段編寫的準(zhǔn)備信息重新構(gòu)建資源的已提交狀態(tài),并相應(yīng)地提交或中止這些事務(wù)。

總之,兩階段提交協(xié)議和資源管理器共同使事務(wù)具有了原子性和持久性。

Transaction 類還提供了 EnlistPromotableSinglePhase 方法來(lái)登記可提升的單階段登記 (PSPE)。這使持久資源管理器 (RM) 可承載和“擁有”以后可在需要時(shí)升級(jí)為由 MSDTC 進(jìn)行管理的事務(wù)。

到此,關(guān)于“怎么掌握ADO.NET資源管理器原理機(jī)制”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI