Redis主从复制配置(原理剖析)


前言

概念:主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master/Leader),后者称为从节点(Slave/Follower), 数据的复制是单向的!只能由主节点复制到从节点(主节点以写为主、从节点以读为主)

一、Redis主从复制的作用

1、数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余的方式。

2、故障恢复:当主节点故障时,从节点可以暂时替代主节点提供服务,是一种服务冗余的方式。

3、负载均衡:在主从复制的基础上,配合读写分离,由主节点进行写操作,从节点进行读操作,分担服务器的负载;尤其是在多读少写的场景下,通过多个从节点分担负载,提高并发量。

4、高可用基石:主从复制还是哨兵和集群能够实施的基础。

二、Redis主从复制环境配置

1.查看默认配置信息

info replication

在这里插入图片描述
当前角色为主节点,没有从节点。

2.配置一主二从的集群模式

在这里插入图片描述

2.1.拷贝配置文件

在这里插入图片描述

2.2.配置redis79.conf文件

在命令模式下敲斜杆( / )这时在状态栏(也就是屏幕左下脚)就出现了 “/” 然后输入你要查找的关键字敲回车就可以了。 如果你要继续查找此关键字,敲字符 n 就可以继续查找了。
修改输出日志:
在这里插入图片描述
修改RDB持久化二进制文件名称:
在这里插入图片描述

2.3.配置redis80.conf文件

修改端口号:
在这里插入图片描述
修改后台运行进程文件:
在这里插入图片描述
修改日志文件:
在这里插入图片描述
修改RDB持久化二进制文件名称:
在这里插入图片描述
修改redis81.conf也是和6380一样的配置,将其中的6380改成6389即可。

3.依次启动三个服务

redis-server dtconfig/redis79.conf

在这里插入图片描述

redis-server dtconfig/redis80.conf

在这里插入图片描述

redis-server dtconfig/redis81.conf

在这里插入图片描述
查看进程:

ps -ef | grep redis

在这里插入图片描述

4.进入三台服务,检查角色信息

redis-cli -p 6381
INFO replication

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
默认情况下,三台都是主机:

5.选举Leader

选择6379作为主节点,其余6380、6381作为从节点,我们只需要配置80、和81从节点即可:

SLAVEOF 127.0.0.1 6379 

在这里插入图片描述
查看6380当前角色信息:
在这里插入图片描述
查看6379主节点信息:
在这里插入图片描述
配置6381从节点:
在这里插入图片描述
查看主节点6379:
在这里插入图片描述
真实的项目中配置不能这么配置,我们应该从配置文件中进行配置,这样才会永久生效:
在这里插入图片描述

6.读写分离,主从复制

注意(重点面试题):主节点可读可写、从节点只能读不能写。

主节点写,数据自动备份至从节点,然而从节点只能读,不能写。
在这里插入图片描述
在这里插入图片描述
尝试在从节点写入数据:
在这里插入图片描述
错误:只能读不能写。

三、主节点宕机,从节点角色任然不变

我们把主节点6379服务停掉后,查看从节点信息:
在这里插入图片描述
再把主节点6379服务开启,写入数据:
在这里插入图片描述
检查从节点信息:
在这里插入图片描述
再次停掉6379服务,再两个从节点中手动选择从节点:
在这里插入图片描述
如果6379再次启动,那么他就没有从节点了,只能重新配置角色。

总结

1、从机只能读,不能写,主机可读可写但是多用于写
2、当主机断电宕机后,默认情况下从机的角色不会发生变化 ,集群中只是失去了写操作,当主机恢复以后,又会连接上从机恢复原状。
3、当从机断电宕机后,若不是使用配置文件配置的从机,再次启动后作为主机是无法获取之前主机的数据的,若此时重新配置称为从机,又可以获取到主机的所有数据。
4、第二条中提到,默认情况下,主机故障后,不会出现新的主机,有两种方式可以产生新的主机:
4、1 从机手动执行命令slaveof no one,这样执行以后从机会独立出来成为一个主机
4、2 使用哨兵模式(自动选举)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DT辰白

你的鼓励是我创作的源泉

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值