paxos算法简单入门

简介: paxos算法简单入门
我们以历史资料为例简单介绍下paxos算法:战国中期,秦国商鞅变法后迅速崛起对外扩张,在函谷关外拉开大军,准备全面入侵山东国家,山东诸国惶惶不可终日,此时公孙衍犀首游说列国,并先后出任魏国韩国赵国等多个国相,提议欲抵抗秦国必须结成同盟,合纵方可破秦。最终有三个国家魏国,楚国,韩国集兵于函谷关外,各占一个山头准备攻打秦国。但是任意一个国家和秦国对抗必败,必须在三个国家中至少有两个国家达成一致,同时进攻。每个国家有主帅(魏王,楚王,韩王)和参谋(魏相犀首,春申君黄歇,韩太子),参谋给出的进攻时间必须得到魏楚韩中任意两个国家的同意,才可决议,但是派出信使有可能被秦国密探捕获,而导致信息丢失。所以达成一致的进攻时间是个难题,就有了下面的paxos算法决议,虽然根据此算法,三国进攻时间最终达成了一致,但是还是被秦张仪以连横之策大败盟军于函谷之外,这都是后话,不在我们算法涉及范围之内。


两个原则:


1:参谋提出提议,分两阶段,第一准备阶段,第二提交提议阶段。


2:决策者始终保存最大编号的信息,编号较小的会拒绝


image.png

20170921102047455.png


  1. 参谋犀首派出信使给魏楚韩(序号为1),魏王楚王收到信息,由于信使被捕,韩王未收到信息。


  1. 魏王楚王收到信息后,派信使告诉参谋犀首已经收到信息,等待具体指示。


  1. 同时参谋黄歇也派出信使送信给魏楚韩(序号为2),魏王未收到,楚怀王,韩王收到信息.


  1. 楚王韩王收到信息后派信使告诉参谋黄歇,信息已收到,等待具体指示。


  1. 参谋犀首收到信息后,派信使告诉魏楚王,具体进攻时间为下月1号。


  1. 魏王收到后,觉得可以,派信使告诉参谋犀首,1号进攻方案认可。


  1. 楚王收到后,因为他保存的最新等待指示的信号是2,所以告诉犀首,1号进攻方案不认可,正在等待最新指示为2的信息。


  1. 参谋黄歇派出信使告诉楚王韩王,进攻时间为下月2号。


  1. 楚王收到后和自己保存的信号对比,发现一致,则告诉参谋黄歇,2号方案认可。同时韩王也表示认可。


  1. 参谋犀首得到的方案不是一半以上(魏王认可,楚王不认可,韩王未知),所以重新发起一次投票。


  1. 因为第7步,已经被告知,最新指示的代号已经是2了,1已经是过去时了。所以派出信使,说最新指示代号升级为3了。


  1. 魏王收到信息后,告诉参谋犀首,我上次已经同意了你的进攻时间,是否更改,等待最新指示。


  1. 楚王收到信息后,告诉参谋犀首,最新指示代号3已收到,我目前同意的进攻时间是2号,等待你的最新指示。


  1. 参谋犀首收到回信后,下发具体作战时间。因为11步已经被告知,最新时间已经更改为2号了。所以犀首这次派出信使携带信息为“最新代号3,作战时间2号”。


  1. 魏王收到后,按最新指示执行,和自己保存的指示代号对比,发现一致,回复犀首,同意


  1. 楚王收到后,和自己保存的代号做对比,发现也一致,回复犀首,同意2号进攻


  1. 这样一次决策就达成一致了,半数以上同意2号进攻。


相关文章
|
3月前
|
机器学习/深度学习 人工智能 算法
深度学习入门:理解神经网络与反向传播算法
【9月更文挑战第20天】本文将深入浅出地介绍深度学习中的基石—神经网络,以及背后的魔法—反向传播算法。我们将通过直观的例子和简单的数学公式,带你领略这一技术的魅力。无论你是编程新手,还是有一定基础的开发者,这篇文章都将为你打开深度学习的大门,让你对神经网络的工作原理有一个清晰的认识。
|
15天前
|
存储 算法 安全
分布式系统架构1:共识算法Paxos
本文介绍了分布式系统中实现数据一致性的重要算法——Paxos及其改进版Multi Paxos。Paxos算法由Leslie Lamport提出,旨在解决分布式环境下的共识问题,通过提案节点、决策节点和记录节点的协作,确保数据在多台机器间的一致性和可用性。Multi Paxos通过引入主节点选举机制,优化了基本Paxos的效率,减少了网络通信次数,提高了系统的性能和可靠性。文中还简要讨论了数据复制的安全性和一致性保障措施。
32 1
|
1月前
|
机器学习/深度学习 算法 Python
机器学习入门:理解并实现K-近邻算法
机器学习入门:理解并实现K-近邻算法
36 0
|
2月前
|
机器学习/深度学习 算法
机器学习入门(三):K近邻算法原理 | KNN算法原理
机器学习入门(三):K近邻算法原理 | KNN算法原理
|
2月前
|
机器学习/深度学习 算法 大数据
机器学习入门:梯度下降算法(下)
机器学习入门:梯度下降算法(下)
|
2月前
|
机器学习/深度学习 算法 API
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
|
2月前
|
机器学习/深度学习 算法
机器学习入门:梯度下降算法(上)
机器学习入门:梯度下降算法(上)
|
4月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
211 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
4月前
|
存储 算法 Java
(五)漫谈分布式之一致性算法篇:谁说Paxos晦涩难懂?你瞧这不一学就会!
没在时代发展的洪流中泯然于众的道理很简单,是因为它们并不仅是空中楼阁般的高大上理论,而是有着完整落地的思想,它们已然成为构建分布式系统不可或缺的底层基石,而本文则来好好聊聊分布式与一致性思想的落地者:Paxos与Raft协议(算法)。
115 6
|
4月前
|
存储 算法
【C算法】编程初学者入门训练140道(1~20)
【C算法】编程初学者入门训练140道(1~20)