Skip to content

Latest commit

 

History

History
136 lines (82 loc) · 5.53 KB

README.md

File metadata and controls

136 lines (82 loc) · 5.53 KB

Paxos For Studying

bilibili分享地址:https://www.bilibili.com/video/BV1C5411L7qT

一、Paxos Overview

  • Paxos( The Part-Time Parliament )共识算法由Leslie Lamport在1989年首次发布,后来由于大多数人不太能接受他的幽默风趣的介绍方法(其实用比喻的方式介绍长篇的理论,确实让人比较难理解),于是在2001年重新写一篇名叫 Paxos Made Simple 论文,相当于原始Paxos算法的简化版,主要讲述两阶段共识协议部分。这篇文章与原始文章在讲述Paxos算法上最大的不同就是用的都是计算机术语,看起来也轻松很多

  • Paxos算法是分布式系统中的一个共识算法家族,也是第一个有完整数学证明的共识算法

  • "世界上只有两种分布式共识算法,一种是Paxos算法,另一种是类Paxos算法"

  • 现在比较流行的zab和raft算法也是基于Paxos算法设计的

二、Basic Paxos

  • Basic Paxos 是在一轮决策中对一个或多个被提议(propose)的值,最终选出一个值达成共识 paxos

  • Basic Paxos 可以解决的问题
    1. 选主
    2. 资源互斥访问
    3. 复制日志的一致性
    4. 其它

  • 容错模型
    1. 异步网络,网络是不可靠的,消息可能丢失、重复、延迟、网络分区,但是不包括拜占庭错误,即消息不会被篡改和伪造
    2. 只要大多数(majority)服务器还运行,决议就能继续进行

  • FLP定理
    1. Agreement:所有server必须对同一个值达成共识
    2. Validity:达成共识的值必须是提议的有效值
    3. Termination:最终会对一个值达成共识(Paxos不一定)

  • Safety & Liveness

    1. Safety(不会有坏事发生):
    • 只有一个值达成共识
    • 一个server不会知道某个值达成共识,除非它真的已经达成共识
    1. Liveness(好事一定会发生):
    • 最终一定会达成共识(在多个proposer的情况下不能保证,即basic paxos是不能保证终止的,为了保证终止就需要选出一个leader,每次的提议只通过一个leader来发起)
    • 如果共识达成最终所有服务器都能知道

  • Paxos 角色构成

    1. Proposer
    • 处理客户端请求,主动发起提议
    1. Acceptor
    • 被动接收来自Proposer的提议消息,并返回投票结果,通知learner
    1. Learner
    • 被动接收来自Acceptor的消息
    1. 实际中一个节点经常扮演三个角色

  • Paxos两阶段协议
  1. Phase1

phase1

  1. Phase2 phase2
  • Paxos经典场景
  1. 单个Proposer发起提议情况

single_proposer

  1. 多个Proposer情况

many_proposer

  1. 死锁情况

live_lock

三、Multi Paxos

  • The Preliminary Protocol(初级协议) -> The Basic Protocol(基本协议) -> The Complete Synod Protocol(完整神会协议) -> The Multi-Decree Parliament(多法令议会协议)

  • 当需要决定多个值时就需要连续执行多次Paxos算法,一般执行一次Paxos算法的过程称作A Paxos Run 或者 A Paxos Instance

  • Multi-Paxos是由The Complete Synod Protocol衍生而来,The Complete Synod Protocol通过选主解决了进展性问题(同时也是满足一致性的)

  • 在Paxos算法中,选主只是为了解决进展性问题,不会影响一致性,即使出现脑裂Paxos算法也是安全的,只会影响进展性

  • 两阶段协议效率太低,可以有优化的空间。在单个Leader的情况下,如果前一次已经accept成功,接下来不再需要prepare阶段,直接进行accept

  • 一般的Multi-Paxos可以简单总结为(选主 + 两阶段的优化),但是选主也不是必须的(舍弃一定的进展性)

  • 多个instance可以并发的进行

  • Multi Paxos通常是指一类共识算法,不是精确的指定某个共识算法

mutil-paxos

四、Implementing State Machine

  1. Basic Paxos -> Multi Paxos -> Replicated State Machine

  2. 本人另一篇关于Raft算法的分享,可以帮助大家更好的理解共识算法的实际应用和实现。

五、Basic Paxos Implement With Go

  • 运行测试用例:go test -v

六、The Part-Time Parliament

七、Reference

  1. The Part-Time Parliament

  2. Paxos Made Simple

  3. FLP定理

  4. Safety & Liveness

  5. Understanding Paxos

  6. Google TechTalks About Paxos

  7. Paxos lecture (Raft user study)

  8. raft-demo

  9. Paxos Made Live - Chubby