免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3506 | 回复: 0

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

求职 : 首席技术执行
招聘 : 首席技术执行
论坛徽章:
204
卯兔
日期: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
发表于 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列,显示的是从服务器最后一次向主服务器发送这个命令距离现在过了多少秒。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP