ZooKeeper分布式分布式系统

paxos协议

2016-08-07  本文已影响466人  zyhuttp

协议解决的问题

paxos解决了分布式系统就某一个值达成一致的问题。下面就分布式系统中选主来介绍paxos协议过程,协议详细过程见https://en.wikipedia.org/wiki/Paxos_(computer_science)

协议过程

在分布式系统中选主最直接的方法是直接选定集群的一个节点为leader,其它的节点为follower,这样引入的一个问题是如果leader节点挂掉,整个集群就挂掉了。需要有一种算法自动选主,如果leader节点挂掉,则从follower节点中选出一个主节点。协议分为这几个角色:

集群中的一个节点可以同时扮演多个角色,协议分为两阶段:

paxos第一阶段.jpg

(1)1a:Prepare
Proposer向所有Acceptor提出Prepare请求,prepare请求包含一个全局唯一递增的序号N1,全局唯一是指每次每个Proposer发起的序号都不一样,递增是指每个Proposer发起的序列号是递增的。
(2)1b:Promise
Acceptor收到Proposer的Prepare请求时,先和Acceptor的maxNum(此Acceptor收到的最大序号)进行比较,如果maxNum > N1,则抛弃此Proposer的请求;maxNum < N1,设置maxNum的值为N1,且maxNum = N1,回复此Acceptor接受的最大编号N及其对应的值V

上一篇下一篇

猜你喜欢

热点阅读