[Paxos] Paxos Made Simple 读后感
Paxos 由著名图灵奖获得者Leslie Lamport提出,该算法是分布式一致性算法中的奠基之作,今天初读此文仅将相关学习心得予以记录。
1.Paxos 是什么?主要用来解决什么问题?
Paxos
是一个用于实现可容错的分布式系统的算法,主要用于保证分布式集群中多备份系统之间的操作和数据的一致性。这样集群中的每台机器对外相当于完全一致,从而其互相之间可以互为备份,从而使得系统能够容忍一定数量的机器出问题(宕机、断网、硬盘损坏等等)。
2.Paxos的基本原理是什么?
介绍paxos的算法之前,首先介绍一个paxos算法中涉及到的几个角色:
proposer
提出提案者,在实际应用中可以理解为request的接受者,该角色接收到用户请求,并向集群提出提案要求执行该request。acceptor
接收者,接收者接收到来自其他的proposer的提案,并按照一定的逻辑决定是否接收当前的提案,也就是是否接收request并准备执行request的角色。learner
学习者,能够从其他节点获取某个被共识之后的提案。
2.1 paxos解决的问题
假设有n个独立的进程分别能够提出一个值,那么pasos算法用于保证这些进程提出的值的其中之一能够被正确处理。
paxos算法的安全性前提条件为:
- 只有被提议的值才有可能被选中,也就是说不可能有凭空出现的值出现;
- 一次只有一个值会被选中;
- 进程不会learn到一个没有被选中的值;
ps:这里的选中是翻译论文中的propose,其实我感觉这里的propose value可以理解为对某个请求的共识,也就是当进程接收到客户的请求时需要paxos算法保证每次各个进程所处理的请求一致。
pasox算法的关键也就是对这种
2.2 paxos算法的论述以及推论
2.2.1 如何选择一个提案?
对于单个服务器而言,可以按照先到先服务的顺序去选择提案,但是对于多个进程怎么保证提案选择?提案可以由任何一个proposer发出,每个acceptor收到提案的顺序会有所不同,如何保证各个acceptor按同样的顺序接收提案是paxos算法的核心。
为了保证其一直性,paxos给出一系列的接收提案的规定及其推论:
P1: An acceptor must accept the firtst proposal that it receives.(任何接收者都按照先来先服务的原则接收提案。)
P1这个会引起另外一个问题:也就是每个进程接收到的提案顺序不一样,这会造成整个系统的不一致
为了解决这个问题,paxos为每个拟接收的提案(后文直接用Request替代好了)分配一个序号,每个acceptor可以同时接收多个Request,但是一个时间只有一个Request会得到一个序号,序号是递增的。每个Request分配需要必须要集群中大多数节点同意,这里的大多数由系统的Intersection Quorum
决定,本场景中的quorum数最少系统节点数目的一半加1。
P2: If a proposal with value v is choosen, then every higger-numbered proposal that is choosen has value v.(如果某个值v在num k的时候被选中,num 大于k的Proposal中能够看到之前选中的v的值)
由P1和P2可以得出一个提案提交的算法:
- 某个节点上的Proposer提出一个新的proposal num k,并发送到其他一定数量的acceptor,让其保证一下两点:(这被称为
PrepareRequest(n)
n是request的序号)
- 不在接收proposal num < k的提案;
- proposal num 小于k的所有提案已经被accept了;
- 如果该Proposer接收到来自大多数的节点对1中的PrepareRequest的回应,那么Proposer会选择Responses中的最大的proposal提案序号,如果responders没有改提案号,Proposer就会自己随机选择一个并和之前的k一起发送
AcceptRequest(n, v)
到acceptors;
P1a: An acceptor can accept a proposal numbered n iff it has not responded to a prepare request having a number greater than n.
2.2.2 Proposal 与Acceptor之间的交互流程
- 阶段一:
Proposer节点接收到客户端请求,向集群中其他Acceptor节点发送该请求提案,并赋给该提案一个最新的序列号,即发送Prepare消息。
sequenceDiagram
Proposer ->> Acceptors: Prepare(n)
- 阶段二:
Acceptor节点接收到Prepare消息之后需要进行检查,如果n的值大于当前该节点之前Prepare的最大的序列号则接受该消息,并在接下来的处理过程中不再接收序列号小于n的其他Prepare消息。
sequenceDiagram
Acceptors ->> Proposer: OK, not accept Prepare.num < n and highest-numbered proposal it has accepted(if any)
- 阶段三:
Proposer节点在阶段一之后等待Acceptor节点的返回,当接收到大于Quorum数量的相应之后,向Acceptor节点发送Accept(n,v)消息。n即Prepare中的序列号,v = (Acceptor返回的其最大的accepted 的序列号)|| (Acceptor没返回的情况下,Proposer节点任意指定)
sequenceDiagram
Proposer ->> Acceptors: Accept(n, v)
- 阶段四:
Acceptors收到Accept之后进行请求的具体执行
3.Paxos有哪些适用领域以及其有哪些限制?
Paxos解决的问题:
- 异步网络环境中,多进程之间操作的一致性
Paxos的前置条件有:
- 该算法只能够适用于系统中不包含拜占庭节点的情况;
- 该算法的正确性前提是系统中不能超过一半的机器出现问题;
4.Paxos的成熟应用以及发展现状?
Paxos目前广泛运用在目前的分布式系统,典型的分布式协调服务有开源的Zookeeper系统以及Google的Chubby,国内的阿里的OceanBase等等。
5.分布式一致性还有哪些算法可以用?分别有哪些有缺点?
比较著名的还有VR,Raft
以及能够容忍拜占庭节点的PBFT等
[Paxos] Paxos Made Simple 读后感的更多相关文章
- paxos made more simple
paxos算法是进入分布式领域的一块基石,有关paxos的讨论有很多精彩的详细论述,很多牛人不惜宝贵时间以大幅详尽段落叙述.感谢他们,paxos more simple 理解paxos前,我建议以面到 ...
- 从分布式一致性到共识机制(一)Paxos算法
从分布式系统的CAP理论出发,关注分布式一致性,以及区块链的共识问题及解决. 区块链首先是一个大规模分布式系统,共识问题本质就是分布式系统的一致性问题,但是又有很大的不同.工程开发中,认为系统中存在故 ...
- 理解分布式一致性:Paxos协议之Basic Paxos
理解分布式一致性:Paxos协议之Basic Paxos 角色 Proposal Number & Agreed Value Basic Paxos Basic Paxos without f ...
- 分布式数据库中的Paxos 算法
分布式数据库中的Paxos 算法 http://baike.baidu.com/link?url=ChmfvtXRZQl7X1VmRU6ypsmZ4b4MbQX1pelw_VenRLnFpq7rMvY ...
- Paxos算法与Zookeeper分析
1 Paxos算法 1.1 基本定义 算法中的参与者主要分为三个角色,同时每个参与者又可兼领多个角色: ⑴proposer 提出提案,提案信息包括提案编号和提议的value; ⑵acceptor 收到 ...
- [转]Raft [Why Not Paxos]
http://blog.csdn.net/cszhouwei/article/details/38374603 动画讲解 http://thesecretlivesofdata.com/raft/ W ...
- [转]Why Not Paxos
http://blog.csdn.net/cszhouwei/article/details/38374603 Why Not Paxos Paxos算法是莱斯利·兰伯特(LeslieLamport, ...
- 一致性算法--Paxos
分布式一致性算法--Paxos Paxos算法是莱斯利·兰伯特(Leslie Lamport)1990年提出的一种基于消息传递的一致性算法.Paxos算法解决的问题是一个分布式系统如何就某个值(决议) ...
- 2PC/3PC/Paxos
在分布式系统中,一个事务可能涉及到集群中的多个节点.单个节点很容易知道自己执行的事务成功还是失败,但因为网络不可靠难以了解其它节点的执行状态(可能事务执行成功但网络访问超时). 若部分节点事务执行失败 ...
随机推荐
- HTTP严格安全传输(HTTP Strict Transport Security, HSTS)chromuim实现源码分析(二)
HTTP严格安全传输(HTTP Strict Transport Security, HSTS)chromuim实现源码分析(一) 下面来查看其他对保存HSTS信息的enabled_sts_hosts ...
- Xcode的中常用到的快捷键,印象笔记中常用到的快捷键
Xcode提供了很多快捷键,灵活使用快捷键可以提升开发效率.但对于初学者来说,一次性的去记住并掌握如此多的快捷键显然是不现实的,本文就是来帮助大家了解在iOS开发过程中,使用最频繁的一些快捷键. 1. ...
- Bat小试牛刀
前天版本发布后同事才发现有点小瑕疵,当然这是前期的设计和测试没到位造成的.撇开这些不说,我想说的是知识面广一点,做起事情来可能更得心应手些. 大致是这样的,由于版本的迭代,导致发布的程序只能清除一部分 ...
- Java集合ArrayList源码解读
最近在回顾数据结构,想到JDK这样好的代码资源不利用有点可惜,这是第一篇,花了心思.篇幅有点长,希望想看的朋友认真看下去,提出宝贵的意见. :) 内部原理 ArrayList 的3个字段 priva ...
- Python自动生产表情包
作为一个数据分析师,应该信奉一句话--"一图胜千言".不过这里要说的并不是数据可视化,而是一款全民向的产品形态--表情包!!!! 表情包不仅仅是一种符号,更是一种文化--是促进社交 ...
- eclipse一直报An internal error occurred during: "Building workspace". GC overhead limit exceeded
最近导入到eclipse里的工程挺大的,每次eclipse启动之后都回update workspace,然后就一直报: An internal error occurred during: " ...
- Spring 4 支持的 Java 8 特性
Spring 框架 4 支持 Java 8 语言和 API 功能.在本文中,我们将重点放在 Spring 4 支持新的 Java 8 的功能.最重要的是 Lambda 表达式,方法引用,JSR-310 ...
- iOS开发之Autolayout
1.概述 在以前的iOS程序中,是如何设置布局UI界面的? (1)经常编写大量的坐标计算代码 (2)为了保证在3.5 inch和4.0 inch屏幕上都能有完美的UI界面效果,有时还需要分别为2种屏幕 ...
- C—动态内存分配之malloc与realloc的区别
在程序的执行期间分配内存时,内存区域中的这个空间称为堆(heap).还有另一个内存区域,称为堆栈(stack),其中的空间分配给函数的参数和本地变量.在执行完该函数后,存储参数和本地变量的内存空间就会 ...
- 多边形剪裁img
<!DOCTYPE html><html><head> <meta charset="utf-8"/> <title>& ...