Redis主从复制集群搭建详解
一、主从复制简介
主从复制原理
主从复制是一种常见的数据同步技术,用于实现Redis集群的高可用和读写分离。

工作流程:
- 当从节点(Slave)第一次连接主节点(Master)时,主节点会启动一个后台进程,将数据库保存到rdb文件中
- 同时主节点会记录后续执行的所有写操作命令
- 后台进程完成rdb文件生成后,主节点将rdb文件发送给从节点
- 从节点收到rdb文件后,先存入磁盘,再加载到内存中
- 之后主节点通过命令传播方式,实时将写命令同步到从节点
主从复制特点
- 数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式
- 故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速故障恢复
- 负载均衡:在主从复制的基础上,可以实现读写分离,分担主节点的压力
- 高可用基石:主从复制是哨兵模式和集群模式的基础
二、环境准备
服务器规划
| IP地址 | 主机名 | 角色 | 操作系统 |
|---|---|---|---|
| 192.168.194.11 | master | 主节点 | RedHat 10.1 |
| 192.168.194.12 | slave1 | 从节点1 | RedHat 10.1 |
| 192.168.194.13 | slave2 | 从节点2 | RedHat 10.1 |
初始化设置
bash
# 配置主机名称
hostnamectl set-hostname master && bash
hostnamectl set-hostname slave1 && bash
hostnamectl set-hostname slave2 && bash
# 配置IP
nmcli c m ens160 ipv4.addresses 192.168.194.11/24 ipv4.gateway 192.168.194.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes
nmcli c m ens160 ipv4.addresses 192.168.194.12/24 ipv4.gateway 192.168.194.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes
nmcli c m ens160 ipv4.addresses 192.168.194.13/24 ipv4.gateway 192.168.194.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes
nmcli c up ens160
# 关闭防火墙
systemctl stop firewalld
# 关闭selinux
setenforce 0
三、安装Redis
1. 下载源码包
bash
# 下载地址:https://redis.io/downloads/
wget http://download.redis.io/releases/redis-8.6.2.tar.gz
2. 编译安装
bash
# 安装C/C++编译工具链
dnf install -y gcc tcl gcc-c++ make
# 解压到/opt目录
tar -xvf redis-8.6.2.tar.gz -C /opt
# 编译安装
cd /opt/redis-8.6.2/
make && make install
3. 分发到其他节点
bash
# 从Master节点复制到其他节点
scp -rp /opt/redis-8.6.2/ root@192.168.194.12:/opt
scp -rp /opt/redis-8.6.2/ root@192.168.194.13:/opt
编译完成后,主要文件位于src目录下:
redis-server:Redis服务器redis-cli:Redis客户端
四、配置主从复制
1. 配置主节点(Master)
bash
# 编辑配置文件
vim /etc/redis/master.conf
主要配置项:
conf
# 第70行:绑定地址(取消注释并修改为0.0.0.0)
bind 0.0.0.0
# 第137行:守护进程模式
daemonize yes
# 第172行:指定日志文件目录
logfile /var/log/redis_master.log
# 第264行:指定数据目录
dir /var/lib/redis
# 第700行:开启AOF持久化
appendonly yes
# 关闭保护模式
protected-mode no
启动主节点Redis:
bash
redis-server /etc/redis/master.conf
2. 配置从节点(Slave)
bash
# 编辑slave节点的配置文件
vim /etc/redis/slave1.conf
主要配置项:
conf
# 绑定地址
bind 0.0.0.0
# 守护进程模式
daemonize yes
# 日志文件
logfile /var/log/redis_slave1.log
# 数据目录
dir /var/lib/redis
# 第287行:指定主节点的IP和端口(取消注释)
replicaof 192.168.194.11 6379
# 开启AOF持久化
appendonly yes
# 关闭保护模式
protected-mode no
启动从节点Redis:
bash
redis-server /etc/redis/slave1.conf
注意:slave1和slave2配置相同,只需要修改对应的日志文件。
bash# slave1的日志配置 logfile /var/log/redis_slave1.log # slave2的日志配置 logfile /var/log/redis_slave2.log
五、验证主从复制
1. 查看主节点日志
bash
# 在Master节点上查看日志
tail -f /var/log/redis_master.log
2. 查看复制状态
bash
# 连接主节点
redis-cli
# 查看复制信息
127.0.0.1:6379> info replication
3. 测试数据同步
bash
# 在主节点写入数据
127.0.0.1:6379> set name jock
OK
# 在从节点查看数据(自动同步)
127.0.0.1:6379> get name
"jock"
如果从节点能获取到主节点写入的数据,说明主从复制搭建成功!
六、常见问题
1. 从节点无法连接主节点
检查项:
- 防火墙是否关闭
protected-mode是否设置为noreplicaof配置是否正确- 网络是否互通
2. 数据不同步
检查项:
- 主从节点的
requirepass和masterauth是否匹配 - AOF/RDB配置是否一致
- 磁盘空间是否充足
3. 从节点只读
从节点默认是只读的,如需写入可使用:
bash
127.0.0.1:6379> config set replica-read-only no