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. Qt编写自定义控件53-自定义宽高下拉框

    一.前言 默认的qcombobox控件,如果元素item中的内容过长超过控件本身的宽度的话,会自动切掉变成省略号显示,有些应用场景不希望是省略号显示,希望有多长就显示多长,还有一种应用场景是需要设置下 ...

  2. 【417】一条语句编译并执行C语言

    参考:shell学习笔记(1)Linux下在一行执行多条命令 要实现在一行执行多条Linux命令,分三种情况: 1.&& 举例: lpr /tmp/t2 && rm / ...

  3. Web登录验证之 Shiro

    1.需要用到的shiro相关包 <!-- shiro begin --> <dependency> <groupId>org.apache.shiro</gr ...

  4. python 中的一些基础算法:递归/冒泡/选择/插入

    递归算法 如果一个函数包含了对自己的调用,那么这个函数就是递归的. 比如我们计算下1-7乘法的计算: def func(n): if n ==1 : return 1 return n*func(n- ...

  5. MySQL数据库表的设计和优化(下)

    二.基于单表设计的多表设计原则:(1)表关系: 一)一对一关系: 定义: 在这种关系中,关系表的每一边都只能存在一个记录.每个数据表中的关键字在对应的关系表中只能存在一个记录或者没有对应的记录.这种关 ...

  6. Spring Aop(十六)——编程式的自定义Advisor

    转发:https://www.iteye.com/blog/elim-2399437 https://www.iteye.com/blogs/subjects/springaop 编程式的自定义Adv ...

  7. 汉化Git Gui

    先来一个图: 其实使用自带的图形化操作git还是很方便的,但是英文界面还是让相当一部分小伙伴不太舒服,比如我哈. 汉化包地址:链接: https://pan.baidu.com/s/1qQtBUsf1 ...

  8. JS CSS写下拉菜单 竖行

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. mysql常用操作及常见问题

    常用操作 mysql备份: --整库备份 docker exec 容器ID mysqldump -uroot -p密码 --databases 库名 > 库名.sql --仅导出表和数据 mys ...

  10. VC++操作注册表(创建,读取,更改,删除)

    #include "stdafx.h" #include <Windows.h> #include <iostream> using namespace s ...