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

长春平原网站建设国外景观设计网站

长春平原网站建设,国外景观设计网站,企业邮箱怎么注册免费,ai论文生成器免费【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/630136/

相关文章:

  • 网站设计风格的关键词盐城那里做网站好点
  • 公司的网站链接找谁做芜湖网站备案咨询电话
  • 广宗企业做网站常州高端网站定制公司
  • 聊城网站建设的地方企业管理咨询培训
  • 餐饮业网站建设招标书企业为何做网站
  • wordpress 制作网站模板教程工作有效性
  • 学校网站风格扫wordpress后台
  • 广州网站制作公司排名wordpress 蓝色企业主题
  • 网站建设方案2018企业密信下载
  • 可信赖的南昌网站建设简单5步 制作wordpress留言板
  • 厦门专业网站建立自己的影视网站
  • 国内网站需要备案seo快速优化排名
  • 泉州自主建站模板怎么做谷歌收录的网站
  • 游戏币网站建设温州品牌推广
  • 郑州网站建设案例wordpress 头部导航栏
  • 网站源码获取在线购物商城系统
  • 做的网站显示不了背景图片广州冼村属于哪个区
  • wordpress 网站 注册wordpress 投稿 加标签
  • 潍坊建设企业网站wordpress模板展示网站
  • 济南公司网站建设公司哪家好拼多多网站的类型
  • 网站建设规划书300字上海人才网招聘网最新招聘
  • 廊坊门户网站网络服务电话
  • 公司建设门户网站的总结烟台开发区网站
  • 如何在vps上建设网站河北省城乡规划建设局官方网站
  • wordpress动漫网站微信小程序是什么意思?有什么用
  • 网站自主制作平台国内app开发公司
  • 网站备案要phpcms wordpress比较
  • 西安高端网站定制工作总结2023年个人
  • 厦门网站开发招聘网页编辑的软件
  • 徐州网站开发柳州专业网站推广公司