免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 37021 | 回复: 0
打印 上一主题 下一主题

redis当中的复制 [复制链接]

求职 : 首席技术执行
招聘 : 首席技术执行
论坛徽章:
219
卯兔
日期:2014-08-21 13:22:47丑牛
日期:2014-09-24 09:48:32季节之章:冬
日期:2015-01-30 13:22:502015年亚洲杯之阿曼
日期:2015-02-04 15:56:37羊年新春福章
日期:2015-02-04 15:56:452015年亚洲杯之乌兹别克斯坦
日期:2015-02-04 15:57:082015年亚洲杯之巴林
日期:2015-02-10 15:31:102015年亚洲杯之沙特阿拉伯
日期:2015-02-10 15:31:13羊年新春福章
日期:2015-02-10 15:31:172015年亚洲杯之澳大利亚
日期:2015-02-10 17:03:112015年亚洲杯之乌兹别克斯坦
日期:2015-02-10 17:03:152015年亚洲杯之中国
日期:2015-02-10 17:03:20
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2020-05-20 16:18 |只看该作者 |倒序浏览
在redis中,用户可以通过执行SLAVEOF命令或者设置slaveof选项,让一个服务器取复制另一个服务器。
传统的复制由于在断连之后,仍旧将复制流程全部走一遍(主服务器保存rdb文件,传输文件,传输命令),导致效率低下;新版的复制在断线后,只执行在断线后没有同步的命令(从服务器发送PSYNC->主服务器发送+CONTINUE->同步命令)。
其实现的原理非常类似于tcp当中的seq和ack,这里由三个部分构成
1. 主服务器的复制偏移量和从服务器的复制偏移量
2. 主服务器的复制积压缓冲区
3. 服务器的运行ID,每个redis服务器,无论主服务器还是从服务器,都会有自己的运行ID,由40个随机的十六进制字符组成。当从服务器对主服务器进行初次复制时,主服务器会将自己的运行ID传送给从服务器,而从服务器会将这个id保存起来。当断线重连的时候,会将这个ID发送过去进行验证。

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

从服务器会以每秒一次的频率,向主服务器发送REPLCONF ACK (复制偏移量)进行心跳检测。在主服务器的从服务器列表当中有一栏lag列,显示的是从服务器最后一次向主服务器发送这个命令距离现在过了多少秒。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP