【5分鐘背八股】2PC提交協(xié)議是什么?

二階段提交(Two-phaseCommit)是指,在計(jì)算機(jī)網(wǎng)絡(luò)以及數(shù)據(jù)庫(kù)領(lǐng)域內(nèi)涡真,為了使基于分布式系統(tǒng)架構(gòu)下的所有節(jié)點(diǎn)在進(jìn)行事務(wù)提交時(shí)保持一致性而設(shè)計(jì)的一種算法(Algorithm)。通常肾筐,二階段提交也被稱(chēng)為是一種協(xié)議(Protocol))哆料。在分布式系統(tǒng)中,每個(gè)節(jié)點(diǎn)雖然可以知曉自己的操作時(shí)成功或者失敗吗铐,卻無(wú)法知道其他節(jié)點(diǎn)的操作的成功或失敗东亦。當(dāng)一個(gè)事務(wù)跨越多個(gè)節(jié)點(diǎn)時(shí),為了保持事務(wù)的ACID特性唬渗,需要引入一個(gè)作為協(xié)調(diào)者的組件來(lái)統(tǒng)一掌控所有節(jié)點(diǎn)(稱(chēng)作參與者)的操作結(jié)果并最終指示這些節(jié)點(diǎn)是否要把操作結(jié)果進(jìn)行真正的提交(比如將更新后的數(shù)據(jù)寫(xiě)入磁盤(pán)等等)典阵。因此,二階段提交的算法思路可以概括為:參與者將操作成敗通知協(xié)調(diào)者镊逝,再由協(xié)調(diào)者根據(jù)所有參與者的反饋情報(bào)決定各參與者是否要提交操作還是中止操作萄喳。

所謂的兩個(gè)階段是指:第一階段:準(zhǔn)備階段(投票階段)和第二階段:提交階段(執(zhí)行階段)

準(zhǔn)備階段

事務(wù)協(xié)調(diào)者(事務(wù)管理器)給每個(gè)參與者(資源管理器)發(fā)送Prepare消息蹋半,每個(gè)參與者要么直接返回失敗(如權(quán)限驗(yàn)證失敗)他巨,要么在本地執(zhí)行事務(wù),寫(xiě)本地的redo和undo日志减江,但不提交染突,到達(dá)一種“萬(wàn)事俱備,只欠東風(fēng)”的狀態(tài)辈灼。

可以進(jìn)一步將準(zhǔn)備階段分為以下三個(gè)步驟:

1)協(xié)調(diào)者節(jié)點(diǎn)向所有參與者節(jié)點(diǎn)詢(xún)問(wèn)是否可以執(zhí)行提交操作(vote)份企,并開(kāi)始等待各參與者節(jié)點(diǎn)的響應(yīng)。

2)參與者節(jié)點(diǎn)執(zhí)行詢(xún)問(wèn)發(fā)起為止的所有事務(wù)操作巡莹,并將Undo信息和Redo信息寫(xiě)入日志司志。(注意:若成功這里其實(shí)每個(gè)參與者已經(jīng)執(zhí)行了事務(wù)操作)

3)各參與者節(jié)點(diǎn)響應(yīng)協(xié)調(diào)者節(jié)點(diǎn)發(fā)起的詢(xún)問(wèn)。如果參與者節(jié)點(diǎn)的事務(wù)操作實(shí)際執(zhí)行成功降宅,則它返回一個(gè)”同意”消息骂远;如果參與者節(jié)點(diǎn)的事務(wù)操作實(shí)際執(zhí)行失敗,則它返回一個(gè)”中止”消息腰根。

提交階段

如果協(xié)調(diào)者收到了參與者的失敗消息或者超時(shí)激才,直接給每個(gè)參與者發(fā)送回滾(Rollback)消息;否則,發(fā)送提交(Commit)消息瘸恼;參與者根據(jù)協(xié)調(diào)者的指令執(zhí)行提交或者回滾操作劣挫,釋放所有事務(wù)處理過(guò)程中使用的鎖資源。(注意:必須在最后階段釋放鎖資源)

接下來(lái)分兩種情況分別討論提交階段的過(guò)程东帅。

當(dāng)協(xié)調(diào)者節(jié)點(diǎn)從所有參與者節(jié)點(diǎn)獲得的相應(yīng)消息都為”同意”時(shí):

image.png

1)協(xié)調(diào)者節(jié)點(diǎn)向所有參與者節(jié)點(diǎn)發(fā)出”正式提交(commit)”的請(qǐng)求压固。

2)參與者節(jié)點(diǎn)正式完成操作,并釋放在整個(gè)事務(wù)期間內(nèi)占用的資源靠闭。

3)參與者節(jié)點(diǎn)向協(xié)調(diào)者節(jié)點(diǎn)發(fā)送”完成”消息帐我。

4)協(xié)調(diào)者節(jié)點(diǎn)受到所有參與者節(jié)點(diǎn)反饋的”完成”消息后,完成事務(wù)阎毅。

如果任一參與者節(jié)點(diǎn)在第一階段返回的響應(yīng)消息為”中止”焚刚,或者 協(xié)調(diào)者節(jié)點(diǎn)在第一階段的詢(xún)問(wèn)超時(shí)之前無(wú)法獲取所有參與者節(jié)點(diǎn)的響應(yīng)消息時(shí):

image.png

1)協(xié)調(diào)者節(jié)點(diǎn)向所有參與者節(jié)點(diǎn)發(fā)出”回滾操作(rollback)”的請(qǐng)求点弯。

2)參與者節(jié)點(diǎn)利用之前寫(xiě)入的Undo信息執(zhí)行回滾扇调,并釋放在整個(gè)事務(wù)期間內(nèi)占用的資源。

3)參與者節(jié)點(diǎn)向協(xié)調(diào)者節(jié)點(diǎn)發(fā)送”回滾完成”消息抢肛。

4)協(xié)調(diào)者節(jié)點(diǎn)受到所有參與者節(jié)點(diǎn)反饋的”回滾完成”消息后狼钮,取消事務(wù)。

不管最后結(jié)果如何捡絮,第二階段都會(huì)結(jié)束當(dāng)前事務(wù)熬芜。

【5分鐘背八股】55:2PC提交協(xié)議是什么?.png

推薦閱讀:【5分鐘背八股】CAP定理是什么福稳?涎拉?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市的圆,隨后出現(xiàn)的幾起案子鼓拧,更是在濱河造成了極大的恐慌,老刑警劉巖越妈,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件季俩,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡梅掠,警方通過(guò)查閱死者的電腦和手機(jī)酌住,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)阎抒,“玉大人酪我,你說(shuō)我怎么就攤上這事∏胰” “怎么了祭示?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我质涛,道長(zhǎng)稠歉,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任汇陆,我火速辦了婚禮怒炸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘毡代。我一直安慰自己阅羹,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布教寂。 她就那樣靜靜地躺著捏鱼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪酪耕。 梳的紋絲不亂的頭發(fā)上导梆,一...
    開(kāi)封第一講書(shū)人閱讀 51,624評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音迂烁,去河邊找鬼看尼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛盟步,可吹牛的內(nèi)容都是我干的藏斩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼却盘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼狰域!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起黄橘,我...
    開(kāi)封第一講書(shū)人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤兆览,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后旬陡,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體拓颓,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年描孟,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了驶睦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡匿醒,死狀恐怖场航,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情廉羔,我是刑警寧澤溉痢,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響孩饼,放射性物質(zhì)發(fā)生泄漏髓削。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一镀娶、第九天 我趴在偏房一處隱蔽的房頂上張望立膛。 院中可真熱鬧,春花似錦梯码、人聲如沸宝泵。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)儿奶。三九已至,卻和暖如春鳄抒,著一層夾襖步出監(jiān)牢的瞬間闯捎,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工嘁酿, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留隙券,地道東北人男应。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓闹司,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親沐飘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子游桩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容