当前位置: 首页 > news >正文

建设银行网站查询房贷信息查询界首做网站

建设银行网站查询房贷信息查询,界首做网站,wordpress 搜索出图片,女装网站建设费用预算【Redis】Redis主从同步中数据同步原理 文章目录【Redis】Redis主从同步中数据同步原理1. 全量同步1.1 判断是否第一次数据同步2. 增量同步3. 优化Redis主从集群4. 总结1. 全量同步 主从第一次同步是全量同步。 数据同步包括以下三个阶段: 在从节点执行slaveof命令…

【Redis】Redis主从同步中数据同步原理

文章目录

  • 【Redis】Redis主从同步中数据同步原理
    • 1. 全量同步
      • 1.1 判断是否第一次数据同步
    • 2. 增量同步
    • 3. 优化Redis主从集群
    • 4. 总结

1. 全量同步

主从第一次同步是全量同步

数据同步包括以下三个阶段:

image-20230228215542719

  1. 在从节点执行slaveof命令后,向主节点请求数据同步,主节点判断从节点是否是第一次同步,如果是第一次,则返回主节点的数据版本信息,从节点保存主节点的版本信息。
  2. 从节点第一次同步,主节点异步执行bgsave命令生成rdb文件,生成完成向从节点发送,从节点则清空本地数据去加载主节点的rdb文件实现一部分数据的同步。这时主节点和从节点之间的数据不一定是一致的。
  3. 如果在主节点执行bgsave的时候,主节点又执行了其他命令,这些命令会记录在 repl_baklog ,主节点发送其中的命令,从节点执行接收到的命令,这时就真正完成了主从数据的一致。

简述全量同步的流程:

  • slave节点请求增量同步
  • master节点判断replid,发现不一致,拒绝增量同步
  • master将完整内存数据生成RDB,发送RDB到slave
  • slave清空本地数据,加载master的RDB
  • master将RDB期间的命令记录在repl_baklog,并持续将log中的命令发送给slave
  • slave执行接收到的命令,保持与master之间的同步

1.1 判断是否第一次数据同步

master通过如下两个概念来判断slave是不是第一次来同步数据:

  • Replication Id:简称replid,是数据集的标记,id一致则说明是同一数据集。每一个master都有唯一的replid,slave则会继承master结点的replid。
  • offset:偏移量,•随着记录在repl_baklog中的数据增多而逐渐增大。slave完成同步时也会记录当前同步的offset。如果slave的offset小于master的offset,说明slave数据落后于master,需要更新。

所以,slave做数据同步必须向master声明自己的 replication idoffset ,master才可以判断到底需要同步哪些数据。

如果slave节点来请求master,必须带着自己的replid和offset,master节点则判断他们俩的replid是否相等,相等则说明不是第一次来,不相等说明是第一次来,做全量同步,并返回主节点的replid和offset,slave节点则继承这些信息。

image-20230228221625453


2. 增量同步

主从第一次同步是全量同步,但如果slave重启后同步,则执行增量同步

image-20230228222543854

注:repl_baklog是一个环形的数组。

repl_baklog的大小有限,写满后会覆盖最早的数据。所以如果slave断开时间过久,导致尚未被封的数据被覆盖,则无法基于log做增量同步,只能再次全量同步。


3. 优化Redis主从集群

  • 在master中配置 repl-diskless-sync yes 启用无磁盘复制,避免全量同步时的磁盘IO。
  • Redis单节点上的内存占用不要太大,减少RDB导致的过多磁盘IO。
  • 适当提高 repl_baklog 的大小,发现slave宕机时尽快实现故障恢复,尽可能避免全量同步。
  • 限制一个master上的slave节点数量,如果实在是太多slave,则可以采用主-从-从链式结构,减少master压力。

image-20230228224412941


4. 总结

简述全量同步和增量同步的区别?

  • 全量同步:master将完整内存数据生成RDB,发送RDB到slave,后续命令则记录在repl_baklog,逐个发送给slave。
  • 增量同步:slave提交自己的offset到master,master获取repl_baklog中从offset之后的命令给slave。

什么时候执行全量同步?

  • slave节点第一次连接master节点时
  • slave节点断开时间太久,repl_baklog中的offset已经被覆盖时

什么时候执行增量同步?

  • slave节点断开又恢复,并且在repl_baklog中能够找到offset时。
http://www.yayakq.cn/news/995509/

相关文章:

  • 服务器做网站免费建商城网站哪个好
  • 郑州专业网站制作科技展馆设计效果图
  • 有没有专门做采购的网站网站如何做才能被百度等收录
  • 重庆网站优化服务中国建设银行网站会员注册
  • 昆山建设招投标网站网站设计工程师是it行业吗
  • 怎么给网站做绿标义县网站建设
  • 网站底部广告wordpress查询数据库页面
  • 网站建设不要摸板南宁网站规划与网页设计
  • 重庆石桥铺网站建设wordpress数据库填写
  • 建设银行官方网站首页个人登录怎么用动图做网站背景
  • 龙口网站制作多少钱建设通官网首页
  • 网站域名是啥小程序代理加盟政策
  • 如何建立网站是什么如何选择番禺网站建设
  • 阜宁做网站的公司鹰潭网站开发
  • 网站建站软件wordpress自带gallery
  • 电脑网站设计页面广告设计与制作需要学什么
  • 在线做印章网站如何网上做个人广告
  • 公司网站友情链接ASP网站开发教程实验总结
  • 长沙seo网站建设电商网站分析报告
  • 微信链接的微网站怎么做注册公司新规定最新2024
  • 二手书交易网站开发毕业设计建设用地规划许可证在哪个官方网站可以查询
  • 物流网站怎么做代理网站建设深圳哪家公司好
  • 做竞拍网站合法吗互联网公司裁员
  • 网站建设实战案例网站开发和网络安全
  • 如何学做网站外包wordpress 登陆id
  • 无代码网站开发平台大学生创新创业大赛负责人简介
  • 做职业资格考试的网站有哪些珠海自助建站
  • 全国最大网站建设免费目前有做电子合同的网站吗
  • 做网站设计收入app管理系统
  • 网站群建设优点网页游戏制作器