zoukankan      html  css  js  c++  java
  • 腾讯开源的 Paxos库 PhxPaxos 代码解读---Accept阶段(一)

    腾讯开源的 Paxos库 PhxPaxos 代码解读---Accept阶段(一)

    在看Accept阶段代码之前, 我们再回想一下 Basic Paxos算法;

        1.  Basic Paxos 算法是为了使集群中的Acceptor们达成一个最终的值, 或者不能达成一个最终的值;

            就是说, 要么达成一个最终的值, 某个时间点上, 多数派节点都是一个一致的值, 这个值就是最终的值;

            否则, 没有多数派在某个时间点达成一个一致的值, 这个值不断被新的提议(Proposal)刷新, 无法达成最终值;

            这种情况一般意味着发生了活锁;

        2.  一个最终的值一旦被确定, 不能再有Proposor发出提议进行修改, 为了确保这点, 有了针对Proposor的约束:

            Proposor必须收到多数派的响应, 才能进行Accept提议; 原因如下:

               

                Proposor只有收到多数派响应消息, 才能确定是否已经有多数派接受过提议(Proposal),

                如果多数派响应消息里面已经携带了接受过的提议, 则有两种可能:

                    1. 多数派已经已经达成了一致, 必然会有某些Acceptor的响应携带了这个值;

                    2. 多数派还没有达成一致, 但是Proposor正好收到了某个已经接受过提议的Acceptor的响应;

                上述情况不论是哪种, Proposor都需要用已有的提议发起Accept请求, 选择最大ProposolID的那个;

                这样是为了促使Acceptor们尽快的达成一致;

        3.  对于Acceptor的约束, 则是必须要大于等于当前已经接受过的最大ProposalID, 才能刷新这个值,;

            我们给出一个典型的场景来说明, 以3个Acceptor为例:

           

            第1个时间片段:

                Proposor1发起Prepare请求(1, null), 成功到达 Acceptor1和Acceptor2, Acceptor的状态如下:

                    Acceptor1(1, null); Acceptor2(1, null); Acceptor3(null, null)

            第2个时间片段:

                Proposor2发起Prepare请求(2, null), 成功到达 Acceptor1和Acceptor2, Acceptor的状态如下:

                    Acceptor1(2, null); Acceptor2(2, null); Acceptor3(null, null)

            第3个时间片段:

                Proposor1发起Accept请求(1, 100), 1 < 2, 被Acceptor拒绝, Acceptor的状态如下:

                    Acceptor1(2, null); Acceptor2(2, null); Acceptor3(null, null)

            第4个时间片段:

                Proposor2发起Accept请求(2, 100), 2=2, 被Acceptor接受, Acceptor的状态如下:

                    Acceptor1(2, 100); Acceptor2(2, 100); Acceptor3(null, null)

            第5个时间片段:

                Proposor1重新发起Prepare请求(3, null), 到达Acceptor2和Acceptor3,

                收到响应之后, 用Acceptor2接受的值发起Accept请求(2,100),成功到达Acceptor2和Acceptor3,

                状态变为如下:

                    Acceptor1(2, 100); Acceptor2(2, 100); Acceptor3(2, 100)

    在处理Prepare和Accept请求时, 我们不仅要考虑网络中的异步情况, 还要考虑在接受一个提议时代码执行的异步情况;

    前面一篇博客已经简单介绍过phxpaxos中Prepare阶段的代码, 下面简单的介绍一下Accept阶段的代码;

    phxpaxossrcalgorithmproposer.cpp

    这里的代码是Proposor的逻辑

    phxpaxossrcalgorithmacceptor.cpp

    这里的代码是Acceptor的逻辑

    下面的图是Proposor发起Accept请求的操作:

    下面的图是Acceptor收到Accept请求的操作:

    下面的图是Propsor收到Acceptor返回响应的操作:

    结束:
    微信开源的Paxos库有很多照顾性能的实现, 后面慢慢讲吧;

  • 相关阅读:
    算法导论笔记:13-01红黑树概念与基本操作
    算法导论笔记:12二叉搜索树
    ansible使用9-Playbooks: Special Topics
    ansible使用8-Best Practices
    ansible使用7-Loops
    ansible使用6-Conditionals
    ansible使用5-Variables
    ansible使用4-Playbook Roles and Include Statements
    ansible使用3-playbook
    ansible使用2-inventory & dynamic inventory
  • 原文地址:https://www.cnblogs.com/lijingshanxi/p/10250878.html
Copyright © 2011-2022 走看看