【学习笔记】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:大学毕业之后也三年了,唯一一次感受到孤独竟然是在福建的深夜,衣柜中发现了一只巨大蟑螂,嗯,确实从小就害怕这个。

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

相关推荐
白帽黑客-晨哥39 分钟前
最适合零基础的渗透测试学习路径:理论+实战+就业,我在湖南网安基地实现了
学习·web安全·渗透测试·实战项目·就业·湖南网安基地
b***65322 小时前
【解决】RESP.app GUI for Redis 连接不上redis服务器
服务器·redis·github
q***44812 小时前
java进阶--多线程学习
java·开发语言·学习
断剑zou天涯7 小时前
【算法笔记】窗口内最大值或最小值的更新结构
java·笔记·算法
Naiva8 小时前
【小技巧】Microchip 把 MPLAB X IDE工程编码改成 UTF-8
笔记
w***48829 小时前
Linux安装redis
linux·运维·redis
ndjnddjxn11 小时前
Rust学习
开发语言·学习·rust
菜鸟‍11 小时前
【后端学习】MySQL数据库
数据库·后端·学习·mysql
陈天伟教授12 小时前
基于学习的人工智能(1)机器学习
人工智能·学习