溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Paxos變種和優(yōu)化方法有哪些

發(fā)布時間:2021-12-21 13:36:19 來源:億速云 閱讀:130 作者:iii 欄目:開發(fā)技術

這篇文章主要介紹“Paxos變種和優(yōu)化方法有哪些”,在日常操作中,相信很多人在Paxos變種和優(yōu)化方法有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Paxos變種和優(yōu)化方法有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

Multi Paxos

首先我們來回顧一下Multi Paxos,Multi Paxos在Basic Paxos的基礎上確定一系列值,其決議過程如下:

Paxos變種和優(yōu)化方法有哪些

phase1a: leader提交提議給acceptor

phase1b: acceptor返回最近一次接受的提議(即曾接受的最大的提議ID和對應的value),未接受過提議則返回空

phase2a: leader收集acceptor的應答,分兩種情況處理

  phase2a.1: 如果應答內容都為空,則自由選擇一個提議value

  phase2a.2: 如果應答內容不為空,則選擇應答里面ID最大的提議的value

phase2b: acceptor將決議同步給learner

Multi Paxos中l(wèi)eader用于避免活鎖,但leader的存在會帶來其他問題,一是如何選舉和保持唯一leader(雖然無leader或多l(xiāng)eader不影響一致性,但影響決議進程progress),二是充當leader的節(jié)點會承擔更多壓力,如何均衡節(jié)點的負載。Mencius[1]提出節(jié)點輪流擔任leader,以達到均衡負載的目的;租約(lease)可以幫助實現(xiàn)唯一leader,但leader故障情況下可導致服務短期不可用。

Fast Paxos

在Multi Paxos中,proposer -> leader -> acceptor -> learner,從提議到完成決議共經(jīng)過3次通信,能不能減少通信步驟?

對Multi Paxos phase2a,如果可以自由提議value,則可以讓proposer直接發(fā)起提議、leader退出通信過程,變?yōu)閜roposer -> acceptor -> learner,這就是Fast Paxos[2]的由來。

Paxos變種和優(yōu)化方法有哪些

Multi Paxos里提議都由leader提出,因而不存在一次決議出現(xiàn)多個value,F(xiàn)ast Paxos里由proposer直接提議,一次決議里可能有多個proposer提議、出現(xiàn)多個value,即出現(xiàn)提議沖突(collision)。leader起到初始化決議進程(progress)和解決沖突的作用,當沖突發(fā)生時leader重新參與決議過程、回退到3次通信步驟。

Paxos自身隱含的一個特性也可以達到減少通信步驟的目標,如果acceptor上一次確定(chosen)的提議來自proposerA,則當次決議proposerA可以直接提議減少一次通信步驟。如果想實現(xiàn)這樣的效果,需要在proposer、acceptor記錄上一次決議確定(chosen)的歷史,用以在提議前知道哪個proposer的提議上一次被確定、當次決議能不能節(jié)省一次通信步驟。

EPaxos

除了從減少通信步驟的角度提高Paxos決議效率外,還有其他方面可以降低Paxos決議時延,比如Generalized Paxos[3]提出不沖突的提議(例如對不同key的寫請求)可以同時決議、以降低Paxos時延。

更進一步地,EPaxos[4](Egalitarian Paxos)提出一種既支持不沖突提議同時提交降低時延、還均衡各節(jié)點負載、同時將通信步驟減少到最少的Paxos優(yōu)化方法。

為達到這些目標,EPaxos的實現(xiàn)有幾個要點。一是EPaxos中沒有全局的leader,而是每一次提議發(fā)起提議的proposer作為當次提議的leader(command leader);二是不相互影響(interfere)的提議可以同時提交;三是跳過prepare,直接進入accept階段。EPaxos決議的過程如下:

Paxos變種和優(yōu)化方法有哪些

左側展示了互不影響的兩個update請求的決議過程,右側展示了相互影響的兩個update請求的決議。Multi Paxos、Mencius、EPaxos時延和吞吐量對比:

Paxos變種和優(yōu)化方法有哪些

為判斷決議是否相互影響,實現(xiàn)EPaxos得記錄決議之間的依賴關系。

到此,關于“Paxos變種和優(yōu)化方法有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

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

AI