学习区块链(五十二)paxos分布式一致性算法2
Posted 区块公社
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了学习区块链(五十二)paxos分布式一致性算法2相关的知识,希望对你有一定的参考价值。
Paxos的实现
chubby中有paxos的具体实现可惜看不到代码,表现形式也不确定,可能是以库的形式提供也可能散布在程序的很多地方。现在手里能拿到的一个是 sourceforge上的开源库libpaxos,作者是一位意大利的帅小伙Marco。和Marco交流后发现他对paxos的理解确实挺深的。虽然 libpaxos现在还没得到商用,但感觉还是挺有前途的;另一个实现是在北大天网实验室的类chubby实现---debby,是使用ICE现实的,看 过之后总觉得有些不太通顺的地方,似乎代码的实现并没有严格遵循paxos算法;还有一个是Diskless Paxos的实现,不使用disk保存状态怎么实现各个角色的“可重启”呢?还没时间研究,应该还是挺有意思的;除了这些,在google code上有paxos的java实现,BerkeleyDB的复制也有使用了paxos算法。在本系列的后续文章中将重点介绍对其中一些实现的理解,以 及给libpaxos做跨windows平台移植遇到的问题。
2
Paxos算法解决的问题
Paxos 算法解决的问题是一个分布式系统如何就某个值(决议)达成一致。一个典型的场景是,在一个分布式数据库系统中,如果各节点的初始状态一致,每个节点都执行相同的操作序列,那么他们最后能得到一个一致的状态。为保证每个节点执行相同的命令序列,需要在每一条指令上执行"一致性算法"以保证每个节点看到的指令一致。节点通信存在两种模型:共享内存(Shared memory)和消息传递(Messages passing)。Paxos 算法就是一种基于消息传递模型的一致性算法。
3
应用场景
场景一:C/S模式的冗余备份的系统
C={C1,C2,C3,........,Cn}代表n个客户端,S={S1,S2,S3,........,Sm}代表m个服务器。在这样的冗余系统中要完成这样的任务:让任何一个Cx提出的请求(提交的数据),能在这m个服务器上都执行(保存)一遍,最终所有的服务器达到一个一致的状态(也就是说每个server相当于一个“replica”,而外部看来似乎只有一个server提够服务,这样设计主要是为了容灾考虑)。这时问题就产生了,由于client与server、server与server之间是用网络连接的,则由网络协议带来的不可靠、不确定性将会影响这m个server到达一个一致状态。
例如:C1、C2先后提出请求,C1要求更新value1,C2要求删除value1。由于网络的不确定,这两个请求到达server的顺序可能是S1(requestC1,requestC2),S2(requestC2、requestC1).....等等,使得操作序列在m个服务器可能各不相同,如果S中的每一个server执行了不同的合法操作序列,将会导致整个系统的不一致问题,所以一致性算法的任务就是保证S中每个处于正常工作的server都将执行一个相同的操作序列,如(requestC1、requestC2)。
C/S模式的冗余备份 系统常常有两种形式:
每一个client和所有的server连接
所有的client和一个server连接(相当于server中的leader),再由这个leader与其他冗余server连接。
不管是那种形式都会受到网络不确定性的影响从而产生操作序列不一致问题。
场景二:系统中各节点是对等关系
在典型的区块链网络中,各个节点是对等的,互为client/server,当一节点发生改变时,其他所有节点也要发生相同的改变。比如在ATC(空中交通管制系统)中有五台供管制员使用的席位(即五台主机),在实际应用中会遇到这样的情况:管制员G1在席位1对参数value1做相应的操作,而几乎同时管制员G2在席位2上也对value1做操作。由于网络传输的不确定性可能会导致这五台主机最终的显示结果不尽相同,产生不一致性的问题。paxos算法就是用来解决这类问题。
Paxos算法利用Majority机制的投票形式保证2F+1的容错能力,即2F+1个结点的系统最多允许F个结点同时出现故障。使得各角色之间的结构、联系比较松散,加之很弱的先决条件,让paxos算法在实际工程中易于实现。使用单增的实例id来标识决议的方式,使得整个算法的并行性更好(id号大的决议可以先于id号小的决议被批准,不会影响决议序列的顺序)。总得来说paxos算法是很巧妙的,Lamport严谨的证明也保证了算法的正确性。在Basic paxos算法基础上发展而来的fastpaxos只用两次消息传递就能通过一个value,比传统的一致性算法减少了一次消息传递。这几年,paxos算法的广泛使用很好的证明了算法的价值。
以上是关于学习区块链(五十二)paxos分布式一致性算法2的主要内容,如果未能解决你的问题,请参考以下文章