Raft采用日志复制形式同步数据|学习笔记

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 快速学习Raft采用日志复制形式同步数据

开发者学堂课程【精通Spring Cloud Alibaba:Raft采用日志复制形式同步数据】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/634/detail/10109


Raft 采用日志复制形式同步数据

内容介绍

一、举例

二、如何实现日志的复制

三、回头看 Raft 协议有什么感悟

四、怎么表述数据一致性问题


一、举例

假设有三个节点为 nacos 领导者超时时间100ms、naocs 跟随者超时时间150ms、nacos 跟随者超时时间200ms,所有请求都会转发给 leader 事件,leader 写完后才会同步给 follower,依然遵循过半机制,这时候要满足过半的跟随者同意接收,leader 才会标记该数据是可提交状态。


二、如何实现日志的复制(数据是如何保持一致性的 类似 zap两阶段提交协议)

1.所有的写的请求都是统一的交给我们的领导角色完成,写入该对应的日志,标记该日志为被提交状态。

2.为了提交该日志,领导角色就会将该日志以心跳的形式发送给其他的跟随者节点,只要满足过半的跟随者可以写入该日志,则直接通知其他的跟随者节点同步该数据,这个过程称作为日志复制过程。


三、回头看下 Raft 协议算法有什么感悟?

其实有很多相似之处,无非在 Zab 协议中是通过 myid 谁大谁为领导,而 Raft 协议中是动态形成的,生成随机数,它也是要满足过半机制的。

image.png

中间 leader 超时时间肯定是最小的


四、怎么表述数据一致性问题

去面试时,谈谈 nacos 集群怎么保持数据一致性问题,原理是根据 Raft 协议去保持数据一致性问题。

选举的过程是怎么样的? (回顾怎么表述数据一致性)

1. 默认的情况下每个节点都是为跟随者。

2. 每个节点会随机的生成一个选举的超时时间,例如大概是100-300ms。

在这个超时的时间范围类必须要等待。

3. 超时时间过后,当前的节点的状态可能由跟随者变为竞选者状态。

会给其他的节点发出选举的投票通知,只要该竞选者有超过半数以上即可选为领导角色。

这点明白后面试官问 nacos 集群其实是一样的,nacos 就是 cp 的模式。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
2月前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
159 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
29天前
|
存储 数据采集 监控
阿里云DTS踩坑经验分享系列|SLS同步至ClickHouse集群
作为强大的日志服务引擎,SLS 积累了用户海量的数据。为了实现数据的自由流通,DTS 开发了以 SLS 为源的数据同步插件。目前,该插件已经支持将数据从 SLS 同步到 ClickHouse。通过这条高效的同步链路,客户不仅能够利用 SLS 卓越的数据采集和处理能力,还能够充分发挥 ClickHouse 在数据分析和查询性能方面的优势,帮助企业显著提高数据查询速度,同时有效降低存储成本,从而在数据驱动决策和资源优化配置上取得更大成效。
126 9
|
3月前
|
PyTorch 算法框架/工具
Pytorch学习笔记(七):F.softmax()和F.log_softmax函数详解
本文介绍了PyTorch中的F.softmax()和F.log_softmax()函数的语法、参数和使用示例,解释了它们在进行归一化处理时的作用和区别。
533 1
Pytorch学习笔记(七):F.softmax()和F.log_softmax函数详解
|
2月前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的联机重做日志文件与数据写入过程
在Oracle数据库中,联机重做日志文件记录了数据库的变化,用于实例恢复。每个数据库有多组联机重做日志,每组建议至少有两个成员。通过SQL语句可查看日志文件信息。视频讲解和示意图进一步解释了这一过程。
|
3月前
|
SQL 存储 关系型数据库
Mysql主从同步 清理二进制日志的技巧
Mysql主从同步 清理二进制日志的技巧
37 1
|
3月前
|
数据采集 机器学习/深度学习 存储
使用 Python 清洗日志数据
使用 Python 清洗日志数据
51 2
|
3月前
|
数据可视化
Tensorboard可视化学习笔记(一):如何可视化通过网页查看log日志
关于如何使用TensorBoard进行数据可视化的教程,包括TensorBoard的安装、配置环境变量、将数据写入TensorBoard、启动TensorBoard以及如何通过网页查看日志文件。
297 0
|
3月前
|
SQL 关系型数据库 MySQL
Hadoop-25 Sqoop迁移 增量数据导入 CDC 变化数据捕获 差量同步数据 触发器 快照 日志
Hadoop-25 Sqoop迁移 增量数据导入 CDC 变化数据捕获 差量同步数据 触发器 快照 日志
53 0
|
4月前
|
SQL 人工智能 运维
在阿里云日志服务轻松落地您的AI模型服务——让您的数据更容易产生洞见和实现价值
您有大量的数据,数据的存储和管理消耗您大量的成本,您知道这些数据隐藏着巨大的价值,但是您总觉得还没有把数据的价值变现出来,对吗?来吧,我们用一系列的案例帮您轻松落地AI模型服务,实现数据价值的变现......
263 3
|
5月前
|
数据库 Java 监控
Struts 2 日志管理化身神秘魔法师,洞察应用运行乾坤,演绎奇幻篇章!
【8月更文挑战第31天】在软件开发中,了解应用运行状况至关重要。日志管理作为 Struts 2 应用的关键组件,记录着每个动作和决策,如同监控摄像头,帮助我们迅速定位问题、分析性能和使用情况,为优化提供依据。Struts 2 支持多种日志框架(如 Log4j、Logback),便于配置日志级别、格式和输出位置。通过在 Action 类中添加日志记录,我们能在开发过程中获取详细信息,及时发现并解决问题。合理配置日志不仅有助于调试,还能分析用户行为,提升应用性能和稳定性。
67 0