【学习笔记】Redis学习笔记——第15章 复制(slaveof)

第15章 复制(slaveof)

15.1 旧版复制功能的实现

1>同步:将从服务器状态同步成主服务器状态

2>命令传播:主服务器修改时,将修改传播到从服务器

15.1.1 同步

1>从服务器向主服务器发送SYNC命令

2>主服务器执行BGSAVE生成RDB文件,并用缓冲区记录所有写命令

3>从服务器载入RDB文件

4>主服务器将缓冲区的写命令发给从服务器执行

15.1.2 命令传播

主服务器不断把写命令发送给从服务器

15.2 旧版复制功能的缺陷

在从服务器断线重连后,会重新执行SYNC,而不是将之前的命令传播

15.3 新版复制功能的实现

PSYNC:在重连后,将断开后的写命令同步

15.4 部分重同步的实现

15.4.1 复制偏移量

主、从各自维护一个复制偏移量,表示已同步的状态字节数

15.4.2 复制积压缓冲区

如果积压缓冲区(1MB)包含了从服务器重新连接后需要写入的全部数据,则进行部分同步,否则进行SYNC

15.4.3 服务器运行ID

每个redis服务器都有自己的ID,从服务器保存了主服务器的运行ID,如果从服务器重新连接后更换了主服务器运行ID,则进行SYNC

15.5 PSYNC命令的实现

略,P209

15.6 复制的实现

1>从服务器设置主服务器的地址和端口

2>建立套接字链接

3>发送PING命令

4>身份验证

5>发送端口信息(主服务器记录从服务器端口信息)

6>同步

7>命令传播

8>可能发生的断线重同步

15.7 心跳检测

每一秒检测一次

15.7.1 检测主从服务器的网络连接状态

主服务器超过一秒未收到从服务器的ACK,则认为连接故障

15.7.2 辅助实现min-slaves配置选项

可配置从服务器最少数量或延迟都大于n秒时主服务器不接受写命令

15.7.3 检测命令丢失

心跳请求中包含偏移量,主服务器可通过该值判断是否发生了命令丢失

★单线程确实具有很多优势,很多功能的实现都可以变得特别简单


(PS:大学毕业之后也三年了,唯一一次感受到孤独竟然是在福建的深夜,衣柜中发现了一只巨大蟑螂,嗯,确实从小就害怕这个。

总是在觉得自己已经成熟,从容面对生活中发生一切的时候遇到一些奇奇怪怪的事情呢。)

相关推荐
MartinYeung57 分钟前
[论文学习]无资料选择性遗忘:透过模型反演实现 LLM 的资料免隐私保护(DFSU)
学习
闪电悠米8 分钟前
黑马点评-Redis 消息队列-02_list_pubsub_limits
java·数据库·ide·redis·缓存·list·intellij-idea
折哥的程序人生 · 物流技术专研16 分钟前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
阿寻寻17 分钟前
【人工智能学习-20260608】什么是生成式AI?
人工智能·学习
IT策士20 分钟前
Redis 从入门到精通:数据结构Set 与 Sorted
数据结构·数据库·redis
sensen_kiss27 分钟前
CPT304 SoftwareEngineeringII 软件工程 2 Pt.5 软件复用(Software Reuse)
学习·软件工程
填满你的记忆32 分钟前
10万QPS下,Redis缓存如何避免雪崩?
数据库·redis·缓存
xian_wwq34 分钟前
【学习笔记】倾斜摄影、高斯泼溅(3DGS)、点云与数字孪生“族谱”全盘点
笔记·学习·3d
伶俜6636 分钟前
# ✨ 零基础学 ArkUI 动画(专题一):从 animateTo 到 Lottie,一篇吃透全部
学习·华为·harmonyos
伶俜6640 分钟前
# [特殊字符] 零基础学 ArkUI 数据持久化(专题三):5 种存储方案深度对比
学习·华为·wpf·harmonyos