摘自redis设计与实现

通过客户端,发送slave of xxx给redis从服务器,即可实现主从服务器之间的复制。如果主服务器设置了requirepass进行身份验证,从服务器需要设置masterauth,只有两个设置项的值相同,同步操作才能进行。

旧版复制功能的实现

复制功能分为同步和命令传播两个操作。

同步操作:

  1. 从服务器向主服务器发送SYNC命令
  2. 主服务器收到SYNC命令后,执行BGSAVE,在后台生成一个RDB文件,并使用一个缓冲区记录从现在开始执行的所有写命令。
  3. 当主服务器的BGSAVE命令执行完毕时,主服务器将RDB文件发送给从服务器。
  4. 从服务器接收并载入RDB文件
  5. 主服务器将记录在缓冲区里面的所有写命令发送给从服务器,从服务器执行这些写命令,将自己的数据库状态更新至主服务器数据库当前所处的状态。

命令传播:

  同步操作执行完成后,每当主服务器执行客户端发送的写命令,主服务器需要执行命令传播操作,即将写命令发送给从服务器执行。

在Redis中,复制分为两种情况:

  1. 初次复制:从服务器以前没有复制过任何主服务器,或者从服务器当前要复制的主服务器和上次复制的主服务器不同。
  2. 断线后重复制

对于断线后重复制,旧版的复制机制是有缺陷的。每次断线后复制,从服务器都会给主服务器发送SYNC命令,主服务器会重新生成一个RDB文件,再发送给从服务器,这一系列操作是非常耗时的。新版复制机制解决了这一问题。

新版复制功能的实现

为了解决旧版复制功能在处理断线重复制情况时的低效问题,Redis从2.8版本开始,使用PSYNC命令代替SYNC命令来执行复制时的同步操作。

对于断线重复制的部分重同步功能,由以下三部分构成:

  1. 主从服务器的复制偏移量
  2. 主服务器的复制积压缓冲区
  3. 服务器的运行ID

主服务器每次向从服务器同步命令时,都会将偏移量同步过去。而从服务器每次发送心跳检测时,或者断开重连后,也会将自己的偏移量带给主服务器。主服务器如果发现从服务器的偏移量小于自己的,就会在缓冲区中查看偏移量之后的命令,将命令重新发送给从服务器。

在命令传播阶段,从服务器默认会以每秒一次的频率,向主服务器发送命令:REPLCONF AK <偏移量>

最新文章

  1. UVa 10720 - Graph Construction(Havel-Hakimi定理)
  2. NSMutableAttributedString 富文本的使用
  3. Codeforces Beta Round #75 (Div. 1 Only) B. Queue 线段树+二分
  4. [Q]自定义纸张大小
  5. 一个强大的封装好的pdo处理类
  6. ecshop添加菜单以及权限分配
  7. springMVC系列之(三) spring+springMVC集成(annotation方式)
  8. 日常开发工作常用linux命令
  9. 查看window系统电脑连接过的wifi密码
  10. SQL参数放在where前后的区别
  11. docker centos7创建consul镜像以及用docker-compose启动镜像
  12. 【Tomcat】压力测试和优化
  13. PHP7 学习笔记(七)如何使用zephir编译一个扩展记录
  14. (Review cs231n) Gradient Calculation and Backward
  15. 企业BI系统应用的切入点及五大策略
  16. Redis持久化磁盘IO方式及其带来的问题
  17. 【JQuery】事件
  18. IOS-H5容器的一些探究:UIWebView和WKWebView的比较和选择
  19. 深入理解JavaScript系列(44):设计模式之桥接模式
  20. js 常用类型转换简写

热门文章

  1. Xamarin 自定义OnKeyDown 再按一次退出程序的实现
  2. NetHack 备忘
  3. 洛谷 P1012 拼数
  4. P3746 【[六省联考2017]组合数问题】
  5. 初识 Python 作业及默写
  6. 小数据池/is和==/再谈编码作业
  7. 【04NOIP普及组】火星人(信息学奥赛一本通 1929)(洛谷 1088)
  8. EasyEarth三维可视化解决方案——智慧林业
  9. mysql下sql语句令某字段值等于原值加上一个字符串
  10. flask 开发用户登录注册功能