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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

paxos协议补充

發布時間:2024/2/28 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 paxos协议补充 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

PAXOS 算法是如何解決腦裂問題的。

這里可以發散下,所謂的“腦”其實就是具備寫能力的系統,“非腦”就是只具備讀能力的系統,對應了 MySQL 集群中的從庫。

下面是一段摘自維基百科的 PAXOS 定義:Paxos is a family of protocols for solving consensus in a network of unreliable processors (that is, processors that may fail).

大致意思就是說,PAXOS 是在一群不是特別可靠的節點組成的集群中的一種共識機制。
Paxos 要求任何一個提議,至少有 (N/2)+1 的系統節點認可,才被認為是可信的,這背后的一個基礎理論是少數服從多數。
想象一下,如果多數節點認可后,整個系統宕機了,重啟后,仍然可以通過一次投票知道哪個值是合法的(多數節點保留的那個值)。
這樣的設定也巧妙的解決了分區情況下的共識問題,因為一旦產生分區,勢必最多只有一個分區內的節點數量會大于等于 (N/2)+1。
通過這樣的設計就可以巧妙的避開腦裂,當然 MySQL 集群的腦裂問題也是可以通過其他方法來解決的,比如同時 Ping 一個公共的 IP,成功者繼續為腦,顯然這就又制造了另外一個單點。

如果你了解過比特幣或者區塊鏈,你就知道區塊鏈的基礎理論也是 PAXOS。區塊鏈借助 PAXOS 對最終一致性的貢獻來抵御惡意篡改。

而本文涉及的分布式應用系統則是通過 PAXOS 來解決分區容忍性。再說本質一點,一個是抵御部分節點變壞,一個是防范部分節點失聯。

大家一定聽說過這樣的描述:PAXOS 是唯一能解決分布式一致性問題的解法。
這句話越是理解越發覺得詭異,這會讓人以為 PAXOS 逃離于 CAP 約束了,所以個人更愿意理解為:PAXOS 是唯一一種保障分布式系統最終一致性的共識算法(所謂共識算法,就是大家都按照這個算法來操作,大家最后的結果一定相同)。
PAXOS 并沒有逃離 CAP 魔咒,畢竟達成共識是 (N/2)+1 的節點之間的事,剩下的 (N/2)-1 的節點上的數據還是舊的,這時候仍然是不一致的。

所以 PAXOS 對一致性的貢獻在于經過一次事務后,這個集群里已經有部分節點保有了本次事務正確的結果(共識的結果),這個結果隨后會被異步的同步到其他節點上,從而保證最終一致性。

總結

以上是生活随笔為你收集整理的paxos协议补充的全部內容,希望文章能夠幫你解決所遇到的問題。

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