文章目录

  • 前言
  • 一、Redis主从复制的作用
  • 二、Redis主从复制环境配置
  • 1.查看默认配置信息
  • 2.配置一主二从的集群模式
  • 2.1.拷贝配置文件
  • 2.2.配置redis79.conf文件
  • 2.3.配置redis80.conf文件
  • 3.依次启动三个服务
  • 4.进入三台服务,检查角色信息
  • 5.选举Leader
  • 6.读写分离,主从复制
  • 三、主节点宕机,从节点角色任然不变
  • 总结



前言

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

一、Redis主从复制的作用

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

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

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

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

二、Redis主从复制环境配置

1.查看默认配置信息

info replication

nginx redis负载均衡 redis负载均衡原理_redis


当前角色为主节点,没有从节点。

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

nginx redis负载均衡 redis负载均衡原理_redis_02

2.1.拷贝配置文件

nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_03

2.2.配置redis79.conf文件

在命令模式下敲斜杆( / )这时在状态栏(也就是屏幕左下脚)就出现了 “/” 然后输入你要查找的关键字敲回车就可以了。 如果你要继续查找此关键字,敲字符 n 就可以继续查找了。

修改输出日志:

nginx redis负载均衡 redis负载均衡原理_主从复制_04


修改RDB持久化二进制文件名称:

nginx redis负载均衡 redis负载均衡原理_主从复制_05

2.3.配置redis80.conf文件

修改端口号:

nginx redis负载均衡 redis负载均衡原理_数据_06


修改后台运行进程文件:

nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_07


修改日志文件:

nginx redis负载均衡 redis负载均衡原理_主从复制_08


修改RDB持久化二进制文件名称:

nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_09


修改redis81.conf也是和6380一样的配置,将其中的6380改成6389即可。

3.依次启动三个服务

redis-server dtconfig/redis79.conf

nginx redis负载均衡 redis负载均衡原理_redis_10

redis-server dtconfig/redis80.conf

nginx redis负载均衡 redis负载均衡原理_主从复制_11

redis-server dtconfig/redis81.conf

nginx redis负载均衡 redis负载均衡原理_redis_12


查看进程:

ps -ef | grep redis

nginx redis负载均衡 redis负载均衡原理_redis_13

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

redis-cli -p 6381
INFO replication

nginx redis负载均衡 redis负载均衡原理_主从复制_14


nginx redis负载均衡 redis负载均衡原理_主从复制_15


nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_16


默认情况下,三台都是主机:

5.选举Leader

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

SLAVEOF 127.0.0.1 6379

nginx redis负载均衡 redis负载均衡原理_redis_17


查看6380当前角色信息:

nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_18


查看6379主节点信息:

nginx redis负载均衡 redis负载均衡原理_主从复制_19


配置6381从节点:

nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_20


查看主节点6379:

nginx redis负载均衡 redis负载均衡原理_主从复制_21


真实的项目中配置不能这么配置,我们应该从配置文件中进行配置,这样才会永久生效:

nginx redis负载均衡 redis负载均衡原理_nginx redis负载均衡_22

6.读写分离,主从复制

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

主节点写,数据自动备份至从节点,然而从节点只能读,不能写。

nginx redis负载均衡 redis负载均衡原理_主从复制_23


nginx redis负载均衡 redis负载均衡原理_主从复制_24


尝试在从节点写入数据:

nginx redis负载均衡 redis负载均衡原理_数据_25


错误:只能读不能写。

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

我们把主节点6379服务停掉后,查看从节点信息:

nginx redis负载均衡 redis负载均衡原理_主从复制_26


再把主节点6379服务开启,写入数据:

nginx redis负载均衡 redis负载均衡原理_主从复制_27


检查从节点信息:

nginx redis负载均衡 redis负载均衡原理_主从复制_28


再次停掉6379服务,再两个从节点中手动选择从节点:

nginx redis负载均衡 redis负载均衡原理_主从复制_29


如果6379再次启动,那么他就没有从节点了,只能重新配置角色。

总结

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