Redis单机主从配置(一主二从)+哨兵模式

将一台Redis服务器的数据复制到其他Redis服务器上,前者称为主节点(master),后者称为从节点(slave),主节点用来写入数据,从节点用来读取数据,数据的复制是单向的,只能从主节点到从节点,每个主节点可以有多个从节点,一个从节点只能有一个主节点

每一台Redis服务器启动的时候,默认都是主节点

主从复制策略:

  • 全量同步(slave初始化阶段)
  1. slave连接master,发送sync命令
  2. master接收到sync命令后,执行bgsave生成rdb文件
  3. master的bgsave命令结束后,向所有slave发送rdb文件快照,发送期间所有写命令存到缓冲区
  4. slave收到文件快照以后,替换旧的文件快照,并载入数据
  5. master完成rdb文件传输以后,把缓冲区中的所有写命令发送给slave
  6. slave完成数据载入接收到master请求,并执行写操作
  7. master每执行一个写操作,就会给slave发送写命令,slave接收到并执行写命令
  • 增量同步(初始化完成之后)

master为复制流维护了一个内存缓冲区,里面存放着复制偏移量和master run id,当slave重新连接master,如果master run id一样并且复制偏移量有效,就会从上次复制的地方继续开始,如果有一个条件不满足,就会进行完全重新同步

配置步骤

1.官网下载安装包 https://redis.io/ 

此实例用的是 redis-5.0.8.tar.gz

2.上传到Linux服务器,并进行解压解压安装包

tar -zxvf redis-5.0.8.tar.gz

3.Redis默认不是后台启动,修改属性设置默认为后台启动

4.复制多个配置文件做主从模式配置(单机主从需要修改,多台机器配置忽略)

5.修改配置文件(单机主从需要修改,多台机器配置忽略)

  • 端口号修改
  • pid文件名字修改
  • log日志文件名字修改
  • dump.rdb文件名字修改

6.主从配置

        开启主从配置以后,从节点只能进行数据读取,不能写入

        

  • 命令行模式配置主从复制

               配置命令: slaveof host port

               命令行配置从机重新启动配置会失效

  • 配置文件配置

                

 7.哨兵模式Sentinel

        新建一个文件名为sentinel.conf并设置内容,要监听的主机,端口号,数字1代表主机挂了,从机进行投票选举新的主机

        

        启动哨兵

将6380停止,故障自动转移,6379升级为master,当6380再次上线,成为6379的slave

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值