最简paxos协议

paxos协议是一种分布式协议,它的目的是在多个参与者中达成一致。这个一致性遵循的是少数服从多数原则。

paxos协议有三个角色:proposer, acceptor, learner。prososer提出建议,acceptor采纳建议,learner通过查询acceptor来得知最后的决定。
一个paxos协议的运行过程是这样的:

1. proposer向每个acceptor提出prepare(requestID)请求,参数requestID是一个单向增长的数字。
2. acceptor以前答应过拒绝这个prepare请求吗?(因为requestID小于以前接受过的requestID)
    Yes->忽略。
    No -> acceptor保证,不会接受了比这个requestID更小的请求。
            acceptor已经accept了某个”值“吗?
            Yes-> 返回requestID, 以前的value。
            No -> 返回requestID
3. 如果大多数acceptor接受了这个prepare请求,proposor会向所有的acceptor发送Accept(requestID, value)请求。  
    如果proposer得到了某个已经accept的value,它就会用这个value发Accept, 而放弃自己想要propose的value。
4. acceptor如果以前答应过拒绝这个requestID的请求(因为requestID小于以前接受过的requestID),它就会忽略这个请求。
    否则,acceptor就接受了这个’值‘。 

上面只是对paxos的一个简单描述,大家可以通过这个描述,做一个时序分析。看看paxos有没有可能产生live lock?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值