定义:主机数据更新后根据配置策略,自动同步到备的Master/slave机制,Master以写为主,Slave以读为主。

Tip:配从(从库)不配主(主库)

1.从库配置:

  slave of 主库IP 主库端口

  每次与master断开连接后,都需要重新连接,除非配置到redis.conf文件中

2.修改配置文件的操作细节:

  一.修改进程管道文件:pidfile

  二.修改端口:port

  三.修改log文件名称

  四.修改dump.rdb名称

  五.开启daemonize yes

3.常用3招(三个窗口端口分别为:6379、6380、6381,后面内容均已此三个端口描述):

  一. 一主二仆(6379为主,6380、6381为仆) :

    

     分别启动三个redis配置,在6380、6381上执行:slaveof 主机的IP 主机端口(例:slaveof 127.0.0.7 6379),使用命令 info replication 查看主备详情

    

    笔记:1.从机不能进行写操作(只能读)

       2.主机(6379)存储数据后,从机(6380、6381)执行slaveof命令,会将主机所有数据备份到从机上来

         3.主机宕掉,从机还是slave角色,并不会上位成为master,链接状态变为down

       4.主机从新启动后,还是master角色,从机的连接状态变为up

       5.从机宕了,恢复后不再与之前的主机有关联,角色变为master,想要变为从机,需要再次执行命令slaveof

  这种一主二仆的模式过于中心化,全部围绕一个主机来做数据备份,下面介绍薪火相传(一个节点接一个节点)的模式

  二. 薪火相传 :

     

      在6381上执行slaveof 127.0.0.1 6380,我们发现,6380既是6379的从机又是6381的主机

      在6379上执行写的命令,在6381上同样能拿到

      

  三. 反客为主 (主机宕掉,从 从机重新选举一个作为新的主机):

     

   命令:slaveof no one (使当前数据库停止与其他数据库同步,转成主数据库)

    操作步骤:

       1. 将三台redis还原回一主二仆的环境(6379为主机,6380与6381作为6379的从机)

       2. 将6379关掉(模拟线上宕机情况),

       3. 在6380中执行命令slaveof no one

       4. 将6381改成6380的从机

       5. 重新将6379启动

      我们发现,6380变成了主机,底下连了一台6381从机,当6379重新连接后,底下没有挂任何从机(区别于一主二仆)

   

4.复制原理:

   1. Slave连接到Master后发送一个sync命令,Master接到命令启动后台的存盘进程(同时收集所有接收到的修改数据的命令集[主库写操作]),后台进程完成后,Master将传送整个数据文件到slave来完成一次同步

   2. 全量复制:第一次slaveof到主库的时候(接收到数据文件后,将其存盘并加载到内存中)

   3. 增量复制:除第一次slaveof外,从库以后都是增量存储数据(接收主库传来的修改命令)

5.哨兵模式(类似反客为主的自动版):

  举例:生产环境,如果凌晨主机宕了,从机通过投票自动选举新的主机

   操作步骤:

    1. 调整环境现在主机是6379,从机为6380与6381

    2. # cd /usr/local/bin (redis的启动目录)

    3. # touch sentinel.conf (配置哨兵监控哪台主机,如果主机挂了,从机如何进行投票选举新的主机,名字绝对不能错)

    4. # vim sentinel.conf,在sentinel.conf加入如下内容: sentinel monitor host6379 127.0.0.1 6380 1

               host6379:被监控的主机名称(自己取)

        1代表主机宕掉后,剩余的从机如果谁的票数多余1票,就将作为新的主机

    5. 启动哨兵模式,执行命令:redis-sentinel sentinel.conf,你会看到如下图案:

      

     从图中发现,哨兵开始巡逻6380与6381,只要6379挂掉,那么这两台从机就开始投票,谁票数多谁上位。

    5. 将主机6379 shutdown,我们看到terminal窗口中出现如下信息:

      

        结论:

        6381变成了新的主机,

          6380变成了6381的从机

        重新将关闭后的6379启动,6379变成了6381的slave

6.复制的缺点:

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

总结:

  工作中一般都是哨兵模式  

Redis之主从复制的更多相关文章

  1. redis的主从复制配置

    redis的主从复制配置 一.     原理 Redis的主从复制功能非常强大,一个master可以拥有多个slave,而一个slave又可以拥有多个slave,如此下去,形成了强大的多级服务器集群架 ...

  2. Redis总结(三)Redis 的主从复制

    接着上一篇,前面两篇我总结了<Redis总结(一)Redis安装>和<Redis总结(二)C#中如何使用redis> 所以这一篇,会讲讲Redis 的主从复制以及C#中如何调用 ...

  3. 实现Redis的主从复制配置

    实现Redis的主从复制配置比较简单,而且容易明白. 下图是要配置的主从复制结构图: 1.说明 Redis主从复制中一个主服务可以有多个从服务,一个从服务可以有多个从服务. 配置比较简单,只需要更改r ...

  4. redis的主从复制部署和使用

    reids一种key-value的缓存数据库目前非常流行的被使用在很多场景,比如在数据库读写遇到瓶颈时缓存且读写分离会大大提升这块的性能,下面我就说说redis的主从复制 首先需要启动多个redis实 ...

  5. redis实现主从复制-单机测试

    一.redis实现主从复制-单机测试1.安装redis tar -zxvf redis-2.8.4.tar.gzcd redis-2.8.4make && make install2. ...

  6. 8. redis的主从复制和sentinal

    一. redis主从复制(读写分离) redis的主从复制分为两类节点:1个master和多个slave,master进行读写操作,slav进行只读操作 启动步骤: 主节点照常启动,slave节点启动 ...

  7. Redis基础学习(五)—Redis的主从复制

    一.概述     Redis的主从复制策略是通过其持久化的rdb文件来实现的,其过程是先dump出rdb文件,将rdb文件全量传输给slave,然后再将dump后的操作实时同步到slave中.让从服务 ...

  8. Redis配置主从复制

    Redis配置主从复制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.操作环境介绍 1>.操作系统环境 [root@node101.yinzhengjie.org.cn ...

  9. Redis的主从复制(十一)

    1>什么是主从复制 持久化保证了即使redis服务重启也不会丢失数据,因为redis服务重启后(在使用aof和rdb方式时,如果redis重启,则数据从aof文件加载)会将硬盘上持久化的数据恢复 ...

  10. 基于配置文件的redis的主从复制

    redis中主从复制有很多种配置方法: 1. 使用配置文件即为redis.conf来配置 在随从redis中配置 # slaveof {masterHost} {MastePort} slaveof ...

随机推荐

  1. Educational Codeforces Round 60 Div. 2

    F:考虑对于每个字母对求出删掉哪些字符集会造成字符串不合法,只要考虑相邻出现的该字母对即可,显然这可以在O(np2)(或小常数O(np3))内求出.然后再对每个字符集判断是否能通过一步删除转移而来即可 ...

  2. 进入Docker容器的4种方式

    进入Docker容器的4种方式 在使用Docker创建了容器之后,大家比较关心的就是如何进入该容器了,其实进入Docker容器有好几多种方式,这里我们就讲一下常用的几种进入Docker容器的方法. 进 ...

  3. sublime3添加verilog自动补全代码段

    前言 sublime默认的verilog自动补全十分垃圾,不过提供了代码段这个功能,你可以自己写个重用率高的代码段减轻工作量.写个模板当tb也很爽啦. 流程 1.打开user文件夹,创建verilog ...

  4. bzoj1559 [JSOI2009]密码

    题目链接:[JSOI2009]密码 我们先看第一问:输出方案数 我们把所有给出来的串丢到AC自动机里面去,然后在建出来的\(trie\)图上跑dp 由于\(n\leq 10\)我们很自然的就想到了状压 ...

  5. 【XSY2718】gift 分数规划 网络流

    题目描述 有\(n\)个物品,买第\(i\)个物品要花费\(a_i\)元.还有\(m\)对关系:同时买\(p_i,q_i\)两个物品会获得\(b_i\)点收益. 设收益为\(B\),花费为\(A\), ...

  6. bit、Byte、bps、Bps、pps、Gbps的单位详细说明及换算

    1. bit 电脑记忆体中最小的单位,在二进位电脑系统中,每1bit 可以代表0 或 1 的数位讯号. 2. Byte 字节单位,一般表示存储介质大小的单位,一个B(常用大写的B来表示Byte)可代表 ...

  7. for循环是怎么工作的

    for...in 是Python程序员使用最多的语句,for 循环用于迭代容器对象中的元素,这些对象可以是列表.元组.字典.集合.文件,甚至可以是自定义类或者函数,例如: 作用于列表 >> ...

  8. kafka清理数据日志

    背景问题: 使用kafka的路上踩过不少坑,其中一个就是在测试环境使用kafka一阵子以后,发现其日志目录变的很大,占了磁盘很大空间,定位到指定目录下发现其中一个系统自动创建的 topic,__con ...

  9. Zabbix监控服务器硬盘状态

    安装Iptables服务: [root@localhost /]# yum install iptables-services [root@localhost /]# vim /etc/sysconf ...

  10. 组件之间的数据传递--Vuex

    安装Vuex: npm install Vuex -S 在main.js中引入 import Vue from 'vue' import App from './App' import Vuex fr ...