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

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

相关推荐
摇滚侠11 分钟前
ElasticSearch 教程入门到精通,文档新增修改,文档查询删除,文档批量新增批量删除,笔记21、笔记22、笔记23
笔记·elasticsearch·搜索引擎
用户9313560027430 分钟前
php代码常见漏洞
笔记
爬山算法30 分钟前
Redis(169)如何使用Redis实现数据同步?
前端·redis·bootstrap
qq_4856689935 分钟前
前端基础入门学习
前端·学习
子夜江寒37 分钟前
HTML 基础知识
前端·学习·html
武帝为此1 小时前
【Redis 数据库介绍】
数据库·redis·缓存
铁锚1 小时前
Redis中KEYS命令的潜在风险与遍历建议
数据库·redis·缓存
Dream Algorithm1 小时前
杠杆和合约之间的区别
笔记·区块链
桌角的眼镜1 小时前
Transformer学习笔记
笔记·学习
思成不止于此2 小时前
MySQL 基础核心知识点全梳理:从入门到实战
数据库·笔记·学习·mysql