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

威海住房建设部官方网站cn域名著名网站

威海住房建设部官方网站,cn域名著名网站,哪有做网站的公司,商城网站备案目录 2.Redis主从 2.1.搭建主从架构 2.2.主从数据同步原理 2.2.1.全量同步 2.2.2.增量同步 2.2.3.repl_backlog原理 2.3.主从同步优化 2.4.小结 2.Redis主从 2.1.搭建主从架构 单节点Redis的并发能力是有上限的#xff0c;要进一步提高Redis的并发能力#xff0c;…目录 2.Redis主从 2.1.搭建主从架构 2.2.主从数据同步原理 2.2.1.全量同步 2.2.2.增量同步 2.2.3.repl_backlog原理 2.3.主从同步优化 2.4.小结 2.Redis主从 2.1.搭建主从架构 单节点Redis的并发能力是有上限的要进一步提高Redis的并发能力就需要搭建主从集群实现读写分离。 2.2.主从数据同步原理 2.2.1.全量同步 主从第一次建立连接时会执行全量同步将master节点的所有数据都拷贝给slave节点流程 这里有一个问题master如何得知salve是第一次来连接呢 有几个概念可以作为判断依据 Replication Id简称replid是数据集的标记id一致则说明是同一数据集。每一个master都有唯一的replidslave则会继承master节点的replid offset偏移量随着记录在repl_baklog中的数据增多而逐渐增大。slave完成同步时也会记录当前同步的offset。如果slave的offset小于master的offset说明slave数据落后于master需要更新。 因此slave做数据同步必须向master声明自己的replication id 和offsetmaster才可以判断到底需要同步哪些数据。 因为slave原本也是一个master有自己的replid和offset当第一次变成slave与master建立连接时发送的replid和offset是自己的replid和offset。 master判断发现slave发送来的replid与自己的不一致说明这是一个全新的slave就知道要做全量同步了。 master会将自己的replid和offset都发送给这个slaveslave保存这些信息。以后slave的replid就与master一致了。 因此master判断一个节点是否是第一次同步的依据就是看replid是否一致。 如图 完整流程描述 slave节点请求增量同步 master节点判断replid发现不一致拒绝增量同步 master将完整内存数据生成RDB发送RDB到slave slave清空本地数据加载master的RDB master将RDB期间的命令记录在repl_baklog并持续将log中的命令发送给slave slave执行接收到的命令保持与master之间的同步 2.2.2.增量同步 全量同步需要先做RDB然后将RDB文件通过网络传输个slave成本太高了。因此除了第一次做全量同步其它大多数时候slave与master都是做增量同步。 什么是增量同步就是只更新slave与master存在差异的部分数据。如图 那么master怎么知道slave与自己的数据差异在哪里呢? 2.2.3.repl_backlog原理 master怎么知道slave与自己的数据差异在哪里呢? 这就要说到全量同步时的repl_baklog文件了。 这个文件是一个固定大小的数组只不过数组是环形也就是说角标到达数组末尾后会再次从0开始读写这样数组头部的数据就会被覆盖。 repl_baklog中会记录Redis处理过的命令日志及offset包括master当前的offset和slave已经拷贝到的offset slave与master的offset之间的差异就是salve需要增量拷贝的数据了。 随着不断有数据写入master的offset逐渐变大slave也不断的拷贝追赶master的offset 直到数组被填满 此时如果有新的数据写入就会覆盖数组中的旧数据。不过旧的数据只要是绿色的说明是已经被同步到slave的数据即便被覆盖了也没什么影响。因为未同步的仅仅是红色部分。 但是如果slave出现网络阻塞导致master的offset远远超过了slave的offset 如果master继续写入新数据其offset就会覆盖旧的数据直到将slave现在的offset也覆盖 棕色框中的红色部分就是尚未同步但是却已经被覆盖的数据。此时如果slave恢复需要同步却发现自己的offset都没有了无法完成增量同步了。只能做全量同步。 2.3.主从同步优化 主从同步可以保证主从数据的一致性非常重要。 可以从以下几个方面来优化Redis主从就集群 在master中配置repl-diskless-sync yes启用无磁盘复制避免全量同步时的磁盘IO。 Redis单节点上的内存占用不要太大减少RDB导致的过多磁盘IO 适当提高repl_baklog的大小发现slave宕机时尽快实现故障恢复尽可能避免全量同步 限制一个master上的slave节点数量如果实在是太多slave则可以采用主-从-从链式结构减少master压力 主从从架构图 2.4.小结 简述全量同步和增量同步区别 全量同步master将完整内存数据生成RDB发送RDB到slave。后续命令则记录在repl_baklog逐个发送给slave。 增量同步slave提交自己的offset到mastermaster获取repl_baklog中从offset之后的命令给slave 什么时候执行全量同步 slave节点第一次连接master节点时 slave节点断开时间太久repl_baklog中的offset已经被覆盖时 什么时候执行增量同步 slave节点断开又恢复并且在repl_baklog中能找到offset时
http://www.hkea.cn/news/14303327/

相关文章:

  • 兴平网站开发百度推广网页版
  • 成品网站w灬源码伊园怎么样可以建设网站
  • 建设工程官方网站仪陇网站建设
  • 免费建购物网站成都网站建设公司优势
  • 网站建设公司排行杭州灰色行业seo大神
  • html网站开发教程东阳网站建设软件开发
  • 在线购物网站 项目图书网站建设策划书
  • 股票推荐怎么做网站wordpress 企业模板 免费
  • 最大的地方门户网站源码福田企业网站优化哪个好
  • 微信怎么做小程序的seo快速排名软件方案
  • 一个服务器可以备案几个网站吗冒充it男给某网站做修复
  • 网站制作技术支持兰州网站建设技能论文
  • 南京公司网站开发建设银行纪念币网站
  • 兰州新晨诚网络科技有限公司谷歌seo济南
  • 百度海外视频网站建设北京云网站建设
  • 如何找有需求做网站的公司苏州网站建设公司排名
  • 网站移动端推广做化妆品等的网站
  • 温州建校网站网址导航大全软件下载
  • 做网站的公司济南赛博科技市场今天郑州最新新闻
  • 专业设计软件百度搜索引擎优化方式
  • 做网站好公司wordpress需求规划书
  • 河南宏业建设管理有限公司网站wordpress启动广告
  • 手机网站制作机构网站关键词优化教程
  • 长沙网站空间北京seo做排名
  • 报告网站开发环境设计网站账号
  • asp.net 网站登陆设计做网站游戏推广赚钱
  • 海南省住房和城乡建设厅网站首页基础网站建设公司
  • 外贸网站如何做推广wordpress怎么加表格
  • 祁东网站开发杭州网站建设多少钱
  • 郑州高端定制网站卡片式设计的网站