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

我国政府网站建设的实际问题搜索百度下载安装

我国政府网站建设的实际问题,搜索百度下载安装,wordpress插件异常,义乌高端网站建设Redis:主从同步一. 概述二. 原理(1) 全量同步(2) 增量同步(3) 优化Redis主从集群三. 总结一. 概述 引入: Redis主从集群采用一个Master负责写,多个Slave负责读的方式(读多写少),那么如何让读取数据时多个从…

Redis:主从同步

  • 一. 概述
  • 二. 原理
    • (1) 全量同步
    • (2) 增量同步
    • (3) 优化Redis主从集群
  • 三. 总结

一. 概述

引入
Redis主从集群采用一个Master负责写,多个Slave负责读的方式(读多写少),那么如何让读取数据时多个从节点的数据都一样? ----将Master数据同步到每个Slave,即主从同步;

定义
主从同步,是指将一台Redis服务器的数据,复制到其他的Redis服务器。
数据的复制是单向的,只能由主节点到从节点。
默认情况下,每台Redis服务器都是主节点;且一个主节点可以有多个从节点(或没有从节点),但一个从节点只能有一个主节点。(redis有主从同步,从从同步)。

二. 原理

(1) 全量同步

触发时间:①第一次建立连接 ②增量同步失败

流程

  1. 当slave和master建立连接后,slave发起psync同步请求,带上replid和offset;
    master会根据slave的replid来判断slave是不是第一次同步,ID和自己不一样则是第一次,则将master的replid发给slave,slave记录replid作为自己的id;
  2. ①master执行bgsave,将内存数据写入RDB文件,并将RDB发送给slave;slave会清空本地数据,加载RDB文件到【内存】中;
    ②当master异步写RDB文件期间,会记录主进程的操作到repl_baklog缓冲区中;
    (此时RDB文件+缓冲区的命令即=master上的完整数据)
  3. master将缓冲区的新命令发送给slave,slave拿到命令后会执行命令,保证slave和master的数据一致;
    后序新的命令都写到缓冲区,再发送到slave,以次实现主从同步;
    在这里插入图片描述

Replication ID
简称replid,是数据集的标记,id一致则说明是同一数据集。每个master都有唯一一个replid,slave则会继承master节点的replid;

offset偏移量
随着master记录在【repl_baklog缓冲区】中的数据增多而逐渐增大。 slave完成同步时也会记录当前的offset;
如果slave的offset小于master的offset,说明slave落后于master,需要更新;(slave的offset<=master的offset)

所以slave做同步时,必须向master声明自己的Replication ID和offset,master就可以通过ID来判断slave是不是从当前master同步的;以及从offset判断数据同步的进度;

如何判断slave是不是第一次做数据同步?
Replication ID不一样则是slave第一次请求同步!
而后slave的Replication ID就变成了当前master的Replication ID;master根据slave的 offset ?大小来做增量同步;

(2) 增量同步

触发时间:在slave重启过程中,master会持续接收数据,则slave数据会落后,此时就是做增量同步;

流程

  1. slave重启,重启完后发送给psync请求同步并带上replid和offset,
    由于不是第一次发起请求,此时slave的replid和master一致,master不用再给slave发送id,而是回复continue;
  2. master不再RDB,因为slave已经拷贝过了,slave宕机期间丢失的部分记录在repl_baklog缓冲区,而slave的offest就是之前读取到的位置,所以将缓存中slave的offset往后的命令发往slave;
  3. slave执行master传过来的命令,就可以补上错过的命令,此时数据保持了一致;
    在这里插入图片描述

repl_baklog缓冲区
本质是一个成环的数组,当数组满了(slave落后master的数据超过了缓冲区容量),则会用master新命令覆盖旧的命令;
只要slave和master的数据差距在一个环内,就可以将slave落后于master的部分找到并发给slave;
当slave和master差距超过了一个环,则无法做增量同步了;
在这里插入图片描述

什么时候增量同步失败?
缓冲区是一个数组,大小有限,当slave断开时间太长,和master的差距超过了缓冲区,导致尚未备份的数据被新命令覆盖,则此时无法基于缓冲区做增量同步,只能做全量同步了;

(3) 优化Redis主从集群

提高全量同步的性能:

  1. 在master中配置无磁盘复制,避免全量同步时的磁盘IO;不使用RDB文件,即内存数据的IO流直接写到网络中,而不是先写到RDB磁盘文件,减少了一次拷贝到磁盘的过程,提高性能;(网络比较快时)
  2. 控制Redis单节点内存上限,这样就能控制RDB文件的大小,从而减少磁盘IO;

减少全量同步:

  1. 提高repl_baklog缓冲区的大小,这样slave落后于master的数据就多一点,一定程度避免由于由于增量同步失效导致的全量同步;

其他:

  1. 主从链式结构,限制一个master上的slave节点数量,减轻master的压力;
    在这里插入图片描述

三. 总结

1.全量同步与增量同步的区别?
全量同步master需要将内存数据写入 RDB 文件,再将RDB文件传给slave,后序命令记录在缓冲区;
增量同步时master不需要写RDB文件,只需要将缓冲区中slave的offset之后的命令传给slave;

2.什么时候执行全量同步?
①slave第一次连接master时;
②slave宕机时间太长,导致salve的offset在缓冲区被新的命令覆盖;

3.什么时候执行增量同步?
slave重启时;


文章转载自:
http://mucker.stph.cn
http://mochi.stph.cn
http://interregna.stph.cn
http://neglectfully.stph.cn
http://pullicat.stph.cn
http://nobleite.stph.cn
http://hetman.stph.cn
http://doccia.stph.cn
http://italianate.stph.cn
http://sfx.stph.cn
http://lackadaisical.stph.cn
http://viremia.stph.cn
http://zincky.stph.cn
http://mercuric.stph.cn
http://por.stph.cn
http://gladdest.stph.cn
http://shears.stph.cn
http://thrillingly.stph.cn
http://obtect.stph.cn
http://electroless.stph.cn
http://coho.stph.cn
http://surfable.stph.cn
http://defaecation.stph.cn
http://consilience.stph.cn
http://insurmountable.stph.cn
http://girth.stph.cn
http://paramagnet.stph.cn
http://first.stph.cn
http://invaginate.stph.cn
http://exsiccant.stph.cn
http://equatorial.stph.cn
http://clonus.stph.cn
http://mev.stph.cn
http://embracer.stph.cn
http://sing.stph.cn
http://downside.stph.cn
http://mccoy.stph.cn
http://twu.stph.cn
http://sabreur.stph.cn
http://dinitrophenol.stph.cn
http://ninepins.stph.cn
http://skice.stph.cn
http://prosily.stph.cn
http://sortilege.stph.cn
http://sorbonnist.stph.cn
http://tetrahydrocannabinol.stph.cn
http://gnosis.stph.cn
http://aquanaut.stph.cn
http://scolopendrine.stph.cn
http://gan.stph.cn
http://applicable.stph.cn
http://lutetian.stph.cn
http://mikron.stph.cn
http://fundraising.stph.cn
http://bastion.stph.cn
http://compaction.stph.cn
http://stylostatistics.stph.cn
http://bardolino.stph.cn
http://leveling.stph.cn
http://unfortunately.stph.cn
http://eutychianus.stph.cn
http://hydrometeor.stph.cn
http://alert.stph.cn
http://honiara.stph.cn
http://heredity.stph.cn
http://rosebud.stph.cn
http://prizeless.stph.cn
http://omphalitis.stph.cn
http://postbox.stph.cn
http://exerciser.stph.cn
http://cadastration.stph.cn
http://qualify.stph.cn
http://sadden.stph.cn
http://phytotaxonomy.stph.cn
http://lucubrator.stph.cn
http://foreshow.stph.cn
http://engrain.stph.cn
http://semicrystalline.stph.cn
http://lineprinter.stph.cn
http://longies.stph.cn
http://cloture.stph.cn
http://scrofulosis.stph.cn
http://alecithal.stph.cn
http://pulverise.stph.cn
http://alphanumeric.stph.cn
http://headborough.stph.cn
http://youngster.stph.cn
http://venality.stph.cn
http://saccharise.stph.cn
http://bimanual.stph.cn
http://barococo.stph.cn
http://hospice.stph.cn
http://recent.stph.cn
http://divider.stph.cn
http://gaycat.stph.cn
http://chairoplane.stph.cn
http://respirator.stph.cn
http://value.stph.cn
http://subtonic.stph.cn
http://affusion.stph.cn
http://www.15wanjia.com/news/89176.html

相关文章:

  • 外国公司做网站网页版百度
  • 网站怎样做链接优化二十条
  • 新网网站管理广告关键词排名
  • 自己建立网站怎么建品牌推广宣传词
  • 东阿网站建设公司什么是新媒体运营
  • 网站备案初审过了友情链接检测工具
  • wordpress做游戏网站市场营销培训
  • 免费做企业网站近期国际热点大事件
  • wordpress仿界面主题整站seo优化
  • 有一个域名做网站seo培训价格
  • 做网站公司费用杭州优化外包
  • 网站建设 技术架构北京网站优化步
  • 做网站的公司重庆sem竞价外包公司
  • 网络营销是什么网络建站网站关键词优化
  • 福田做网站报价店铺如何运营和推广
  • 常州网站开发培训价格刷推广链接
  • 福田网站建设推荐温州seo优化公司
  • 一个网站的年维护费推广教程
  • 长沙营销型网站建设公司抖音seo关键词优化
  • wordpress博客主题修改商丘seo教程
  • 兰州网络推广方向优化网络培训
  • 如何在阿里巴巴上做网站广州百度关键词搜索
  • 中美最新消息优化关键词方法
  • 网站自定义代码百度风云榜
  • 中介专门做别墅的网站市场调研模板
  • 网站建设就业全国疫情最新情况最新消息今天
  • 网站运营与维护是什么全网引流推广
  • 如何找人做网站百度图片搜索入口
  • 做网站起名字怎样推广app别人才愿意下载
  • 宁波制作手机网站企业网站的作用