热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

分布式Raft算法介绍

高可用性,高稳定性以及数据一致性是衡量服务的三个基本要素。其中数据一致性在分布式服务中是根基----不管是强一致性还是最终一致性等都需要保证其数据的一致性࿰

 高可用性,高稳定性以及数据一致性是衡量服务的三个基本要素。其中数据一致性在分布式服务中是根基----不管是强一致性还是最终一致性等都需要保证其数据的一致性,不然高可用和高稳定没有任何意义(即便服务容忍一定时延的不一致)。

分布式一致性的保证:

数据保证一致性主要是这两种形式:一种是集群只有一个节点能进行数据的增删改,然后其它节点和单前节点进行同步数据。第二种就是集群节点通过沟通下在合适的时间大家一起进行数据的增删改数据来达到数据一致性。这两种方式细想下它们都需要有一个发起人,由发起人开个头然后集群开始数据的同步操作,这个发起人也就成为leader。

如何选leader比如:

方式一 :大家都读数据库然后读取时增加读锁,谁获取了值就是leader,这种方式在获取锁时需要连接数据库,执行查询操作,增加锁,执行完操作后释放锁,同时还有单点问题,性能瓶颈,通过这种方式提供的锁服务无法满足需求,同时获取了锁的节点如果挂了呢? 或者获取锁的节点在脑裂网络区间呢? 这种方式选取leader不合适。

方式二:由一台服务器与所有机器保持心跳,当需要选择leader时 就在其中随机选择一台,同时通知所有的,如果超过半数同意就成功了。问题关键是一台服务器和所有机器保持心跳,为了提高高可用性增加备用机器,在这台机器挂掉后,备用机器需要和所有机器建立连接,为了提高速度,使用热备,master和热备也用心跳保持关系,一旦挂掉,就接过master的权限,执行其职能,同时客户机的配置中需要增加关于这两台机器的配置,方便为其创建连接,同时检测连接是否正常,这种方式就算出现脑裂问题也不影响,一切以连接到master机器上的所有节点为准。

方式三:集群中每个节点与其余所有节点共同商量谁来当leader。

目前业界使用的不管是Paxos还是Raft算法以及它们的变种算法都是采用方式三来进行leader选举。方式二有点资源浪费,但是按照常理来讲参与决策方越多效率越低,方式二却是避免了这种方式(暂时用不上)。

Raft算法由于其容易理解和实现等原因开始在后期大受欢迎比如:etcd就是基于此实现的,而大名鼎鼎的Kubernetes是基于etcd实现的(间接基于Raft),以及百度的braft(raft变种)。

Raft算法实现一致性通过实现下面:

》选择leader----这个是用来保证其是第一个执行操作的,保证独立性,不会在别的节点同时出现别的操作。

》日志复制----这是leader节点执行操作产生的操作日志,用来和leader节点保存一致,这是选举leader的原因,然后把日志复制到其余节点,每个节点执行成功以后就可以保证和leader节点保证一致了,这和传统的2pc(2 phase commit 2阶段提交) 优势在于---2pc在整个过程中是hold全部资源的,需要全部节点执行成功后才能释放而这个只需要leader节点执行成功,然后保存到日志并复制到别的节点后就可以了,其余节点什么时候执行,自有各个节点来保证日志的执行, 在leader任期内执行别的操作时必须 上一个执行的操作的log的日志已经分发到别的所有大部分节点了,不需要执行,只需要保存,后期执行就可以。

Raft这种算法选举时对性能有一定影响,不仅是Raft,其余的选举算法,随着节点的增加,选举的效率就越低,比如etcd就是建议部署3或5个节点就可以。如果需要大规模选举可以采用上面的方式二。(这就好比股票的撮合交易竞价或者是区块链中有比特币的公共链到联盟链等转换)。

问题:

选举时如何得知其获得了大多数选票,节点是会挂的,会随时变化:

当前节点参加选举时会和其余节点通讯,如果在通讯的大多数节点都同意,那就ok,那问题又来了,如何保障能和其它节点都能通讯? 这个除非节点挂掉,如果在投后节点挂掉了也不影响,因为只能投给一个节点不能再投别的节点,投票前挂掉不没有影响。还有一种就是脑裂问题,这可能会在不同区域都选举一个区域的leader,对于脑裂问题 可以人工干预或者定时检查,对于脑裂区域是否不提供服务或者提供部分服务这个依据具体业务场景来。




推荐阅读
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 2021最新总结网易/腾讯/CVTE/字节面经分享(附答案解析)
    本文分享作者在2021年面试网易、腾讯、CVTE和字节等大型互联网企业的经历和问题,包括稳定性设计、数据库优化、分布式锁的设计等内容。同时提供了大厂最新面试真题笔记,并附带答案解析。 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
  • 区块链为什么是不可篡改的
    不可篡改是区块链最为重要的特性和应用之一。其是由区块链本身的结构、共识机制、网络拓扑和加 ... [详细]
  • 有了中值联区块链证书我们对钓鱼网站说“不”
    区块链钓鱼网站、木马区块链程序、区块链病毒……对个人用户而言,来自区块链网络安全的威胁仅仅停留在这个层面。然而,随着“互联网”战略的持续推进࿰ ... [详细]
  • 可编辑区块链:打破你对“不可篡改”的认知,但这样的区块链还安全吗
    很多人最初了解区块链是什么的时候,除了比特币和中本聪的白皮书,听到最多的说法应该是“去中心化且不可篡改的分布式账本”。由此,区块链“不可篡改”的特性一直都深入人心。不可篡改,我是这 ... [详细]
  • 前面刚有AWS开战MongoDB,双方“隔空互呛”,这厢又曝出2亿+简历信息泄露——MongoDB的这场开年似乎“充实”得过分了些。长期以来,作为“最受欢迎的NoSQL数据库”,M ... [详细]
  • 为元宇宙提供动力的 5 项重要技术
    元宇宙是你肯定听说过的东西。在过去的一年里,每个人都在谈论它。这是技术领域的下一件大事。Bloomberg情报高级行业分析师马修·坎特曼(MatthewKanterman)的分析显 ... [详细]
  • 区块链技术的应用案例展示
    按照行业主流观点,区块链技术应用将经历数字货币(1.0)、合约(2.0)和社会治理(3.0)阶段,当前正逐渐迈入合约阶段。一、区块链1.0:数字货币区块链技术伴随比特币应用而生,比 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 从Oracle安全移植到国产达梦数据库的DBA实践与攻略
    随着我国对信息安全和自主可控技术的重视,国产数据库在党政机关、军队和大型央企等行业中得到了快速应用。本文介绍了如何降低从Oracle到国产达梦数据库的技术门槛,保障用户现有业务系统投资。具体包括分析待移植系统、确定移植对象、数据迁移、PL/SQL移植、校验移植结果以及应用系统的测试和优化等步骤。同时提供了移植攻略,包括待移植系统分析和准备移植环境的方法。通过本文的实践与攻略,DBA可以更好地完成Oracle安全移植到国产达梦数据库的工作。 ... [详细]
author-avatar
龙娃爸爸3
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有