绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
redis当中的复制
2019-09-14 06:27:51
在redis中,用户可以通过执行SLAVEOF命令或者设置slaveof选项,让一个服务器取复制另一个服务器。
传统的复制由于在断连之后,仍旧将复制流程全部走一遍(主服务器保存rdb文件,传输文件,传输命令),导致效率低下;新版的复制在断线后,只执行在断线后没有同步的命令(从服务器发送PSYNC->主服务器发送+CONTINUE->同步命令)。
其实现的原理非常类似于tcp当中的seq和ack,这里由三个部分构成
1. 主服务器的复制偏移量和从服务器的复制偏移量
2. 主服务器的复制积压缓冲区
3. 服务器的运行ID,每个redis服务器,无论主服务器还是从服务器,都会有自己的运行ID,由40个随机的十六进制字符组成。当从服务器对主服务器进行初次复制时,主服务器会将自己的运行ID传送给从服务器,而从服务器会将这个id保存起来。当断线重连的时候,会将这个ID发送过去进行验证。

在开始同步的时候,从服务器是主服务器的客户端,以验证功能,身份等信息,这个阶段需要从服务器向主服务器发送命令;当开始真正同步数据的时候,主服务器又需要变为从服务器的客户端,因为这个时候需要主服务器向从服务器发送命令,在同步进行时,从服务器和主服务器都会有双重身份。

从服务器会以每秒一次的频率,向主服务器发送REPLCONF ACK (复制偏移量)进行心跳检测。在主服务器的从服务器列表当中有一栏lag列,显示的是从服务器后一次向主服务器发送这个命令距离现在过了多少秒。
分享好友

分享这个小栈给你的朋友们,一起进步吧。

NoSQL与NewSQL
创建时间:2020-06-17 14:29:11
关注NoSQL与NewSQL,专区一站找到所需资料!
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • 小雨滴
    专家
戳我,来吐槽~