Redis的复制(Master/Slave)

  a)是什么

  行话:也就是我们所说的主从复制,主机数据更新后根据配置和策略,自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主

  

  b)能干吗

  1.读写分离

  2.容灾恢复

  c)怎么用

  1.配从不配主

  2.从库配置:slaveof  主库IP  主库端口 

    每次与master断开之后,都需要重新连接,除非你配置进redis.cong文件

    info  replication  查看当前库的主从配置信息

  3.修改配置文件细节操作

    拷贝多个redis.conf文件,目的是以不用的配置文件(不同的端口,不同的日志文件名等)启动多个Redis服务

    开启 daemonize  yes

    pid文件名字

    指定端口

    log文件名字

    dump.rdb名字

  4.常用三招

    1.一主二仆  一个Master两个Slave

    主从复制问题演示:

    1 切入点问题?slave1、slave2是从头开始复制还是从切入点开始复制?比如从k4进来,那之前的123是否也可以复制

    2 从机是否可以写?set可否?

    3 主机shutdown后情况如何?从机是上位还是原地待命

    4 主机又回来了后,主机新增记录,从机还能否顺利复制?

    5 其中一台从机down后情况如何?依照原有它能跟上大部队吗?

      

    2.薪火相传

      上一个Slave可以是下一个Slave的Master,Slave同样可以接收其他Slaves的连接和同步请求,那么该slave作为了链条中下一个的master,可以有效减轻master的写压力

      中途变更转向:会清除之前的数据,重新建立拷贝最新的 

      slaveof 新主库IP 新主库端口 

    3.反客为主

      SLAVEOF  no  one  使当前数据库停止与其他数据库的同步,转成主数据库     

      

  d)复制原理

  slave启动成功连接到master后会发送一个sync命令

  Master接到命令启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令,在后台进程执行完毕之后,master将传送整个数据文件到slave,以完成一次完全同步

  全量复制:而slave服务在接收到数据库文件数据后,将其存盘并加载到内存中。

  增量复制:Master继续将新的所有收集到的修改命令依次传给slave,完成同步

  但是只要是重新连接master,一次完全同步(全量复制)将被自动执行

  即从机连接主机时,主机会把修改数据的命令完全拷贝一份,发送给从机,从机拿到这份命令文件,会全部执行文件中的所有命令,即让从机和主机中存储的数据保持一致,

  后面主机再进行数据的修改,就把新增的那部分再给从机,从机再执行保持一致性

注:MySQL中主从复制类似,但是好像是没全量复制的,只有增量复制

  e)哨兵模式  反客为主的自动版

  能够后台监控主机是否故障,如果故障了根据投票数自动将从库转换为主库

  一组sentinel 能同时监控多个Master

  怎么启动:

    1.自定义的 /myredis目录下 新建sentinel.conf文件名字绝不能错

    2.配置哨兵,填写内容

      sentinel   monitor   被监控数据库名字(自己起名字)127.0.0.1    6379   1

      上面最后一个数字1,表示主机挂掉后slave投票看让谁接替主机,得票数多少够成为主机

    3.启动哨兵

      redis-sentinel  /myredis/sentinel.conf  

      上述目录依照各自的实际情况配置,可能目录不同

 

  结果:如果原先监听的master 挂掉了,上位了一个新的master,哨兵会去监听这个新的master,哨兵会去监听这个新的master,老master如果回来,会被 slave 到新的master下

  如果这个新的master又挂掉了,又会从slave中选出新的master,哨兵再去监听master,之后所有连接回来,都会变成slave

  另外,如果启动哨兵模式后,从机挂了,后面再连上,也会自动连接到主机上,不用再SLAVEOF

主从复制的缺点:复制延时

  由于所有的写操作都是先在Master上操作,然后同步更新到Slave上,所以从Master同步到Slave机器有一定的延迟,当系统很繁忙的时候,延迟问题会更严重,Slave机器数量的增加也会使这个问题更加严重  

              

   

  

  

8.Redis的复制(Master/Slave)的更多相关文章

  1. Redis的复制(Master/Slave)

    是什么 : 也就是我们所说的主从复制,主机数据更新后根据配置和策略,自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主 能干嘛: 读写分离,容灾恢复 怎么玩: 1 ...

  2. Redis学习十:Redis的复制(Master/Slave)【重要】

    一.是什么 官网 行话:也就是我们所说的主从复制,主机数据更新后根据配置和策略,自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主 二.能干嘛 读写分离  容灾恢 ...

  3. redis高可用 - Master&Slave

    Master&Slave也就是我们所说的主从复制,即主机数据更新后根据配置和策略,自动同步到备机的机制.其中Master以写为主,Slave以读为主. Master&Slave的作用主 ...

  4. Redis 的主从复制(Master/Slave)

    目录 1. 是什么 2. 能干嘛 3. Redis主从复制讲解 (1). info replication:查看 目标redis 主从情况 (2) . 配从库不配主库 (3). 常用策略 (4). 复 ...

  5. Redis的自从复制(Master/Slave)

    一.是什么? 行话:也就是我们所说的主从复制,主机数据更新后根据配置和策略,自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主 二.能干嘛? 1.读写分离 2.容 ...

  6. Redis master/slave,sentinel,Cluster简单总结

    现在互联网项目中大量使用了redis,本文著主要分析下redis 单点,master/slave,sentinel模式.cluster的一些特点. 一.单节点模式 单节点实例还是比较简单的,平时做个测 ...

  7. Redis的master/slave复制

    摘自:Redis的master/slave复制 Redis的master/slave数据复制方式可以是一主一从或者是一主多从的方式,Redis在master是非阻塞模式,也就是说在slave执行数据同 ...

  8. Redis(八):Redis的复制(Master/Slave)

    Redis的复制(Master/Slave)目录导航: 是什么 能干嘛 怎么玩 复制原理 哨兵模式(sentinel) 复制的缺点 是什么 官网 行话:也就是我们所说的主从复制,主机数据更新后根据配置 ...

  9. Redis的复制(Master/Slave)、主从复制、读写分离

    1.什么是Redis的复制 行话:也就是我们所说的主从复制,主数据更新后根据配置和策略自动同步到备用机的master/slave机制,Mater以写为主,slave以读为主. 2.能干什么 2.1.读 ...

随机推荐

  1. 阶段5 3.微服务项目【学成在线】_day18 用户授权_04-方法授权-方法授权实现

    2.3 方法授权实现 2.3.1资源服务添加授权控制 1.要想在资源服务使用方法授权,首先在资源服务配置授权控制 1)添加spring-cloud-starter-oauth2依赖. 2)拷贝授权配置 ...

  2. OpenStack Magnum项目简介

    1 项目简介 Magnum是OpenStack中一个提供容器集群部署的服务. Magnum是一个Pass层的OpenStack项目. Magnum使用Heat部署一个包含Docker和Kubernet ...

  3. 123457123456#0#-----com.threeapp.ErTongPaint01-----儿童宝宝绘画涂鸦游戏02

    com.threeapp.ErTongPaint01-----儿童宝宝绘画涂鸦游戏02

  4. Python项目开发之CMDB理解与分析

    CMDB的由来--ITIL ITIL就是IT基础架构库(Information Technology Infrastructure Library, ITIL,信息技术基础架构库),由英国政府部门CC ...

  5. jenkins:从FTP服务器下载文件

    lftp 账号:密码@192.168.207.2 lcd /home/eccore/app/chen get -c /基础运维共享文件/OK-TeamViewer14.2.2558.rar

  6. 使用jenkins+sonar进行代码扫描,并发送自定义邮件

    jenkins架构 1.一台机器作为jenkins master不进行构建操作,只负责调度其他slave节点执行任务 2.一台slave机器作为执行机器存放从gitlab上拉取的代码,使用sonar- ...

  7. 表格组件---bootstrapTable

    bootstrapTable中文官方网站http://bootstrap-table.wenzhixin.net.cn1.文件引用 //1.引用Jquery <script src=" ...

  8. numpy 构建深度神经网络来识别图片中是否有猫

    目录 1 构建数据 2 随机初始化数据 3 前向传播 4 计算损失 5 反向传播 6 更新参数 7 构建模型 8 预测 9 开始训练 10 进行预测 11 以图片的形式展示预测后的结果 搭建简单神经网 ...

  9. Matlab给曲线添加加参考线

    声明:引用请注明出处http://blog.csdn.net/lg1259156776/ 对于Matlab的使用情况常常是这样子的,很多零碎的函数名字很难记忆,经常用过后过一段时间就又忘记了,又得去网 ...

  10. C/C++.控制台输入(cin/getchar)

    1.类似的函数有:cin.getchar.fgetc 等 2.问题: 最后的"\n"都不取出来... 2.1.对策:(ZC:下面是 我自己使用后的感受) (1)fflush(std ...