Redis主从复制集群搭建详解

Redis主从复制集群搭建详解


一、主从复制简介

主从复制原理

主从复制是一种常见的数据同步技术,用于实现Redis集群的高可用和读写分离。

工作流程

  1. 当从节点(Slave)第一次连接主节点(Master)时,主节点会启动一个后台进程,将数据库保存到rdb文件中
  2. 同时主节点会记录后续执行的所有写操作命令
  3. 后台进程完成rdb文件生成后,主节点将rdb文件发送给从节点
  4. 从节点收到rdb文件后,先存入磁盘,再加载到内存中
  5. 之后主节点通过命令传播方式,实时将写命令同步到从节点

主从复制特点

  • 数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式
  • 故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速故障恢复
  • 负载均衡:在主从复制的基础上,可以实现读写分离,分担主节点的压力
  • 高可用基石:主从复制是哨兵模式和集群模式的基础

二、环境准备

服务器规划

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 是否设置为 no
  • replicaof 配置是否正确
  • 网络是否互通

2. 数据不同步

检查项:

  • 主从节点的 requirepassmasterauth 是否匹配
  • AOF/RDB配置是否一致
  • 磁盘空间是否充足

3. 从节点只读

从节点默认是只读的,如需写入可使用:

bash 复制代码
127.0.0.1:6379> config set replica-read-only no
相关推荐
清溪5494 分钟前
pgAdmin4 <= 9.1_RCE(CVE-2025-2945)复现
数据库·后端
清溪54919 分钟前
pgAdmin4后台Restore RCE(CVE-2025-13780)复现
数据库·后端
煎饼皮皮侠43 分钟前
【设计】设计一个web版的数据库管理平台后端(之三) -- 多数据库通用分页
数据库·web数据库·查询平台
Rick19931 小时前
mysql联合索引经典实例
java·数据库·mysql
anew___1 小时前
《数据库原理》精要解读(七)—— 数据库设计:从蓝图到现实的系统工程
数据库·oracle
独隅1 小时前
MySQL 接入不同 AI 大模型进行数据管理的全面指南(MySQL + AI)
数据库·人工智能·mysql
go不是csgo1 小时前
GORM 上手:一个 main.go 跑通 Go 数据库增删改查
jvm·数据库·golang
lld9510271 小时前
(一)云回测:量化策略上线前的必经之路
java·服务器·数据库
Old Uncle Tom2 小时前
Harness Engineering 综述
java·开发语言·数据库
疯狂打码的少年3 小时前
Cache的三种映射方式(直接/全相联/组相联)
linux·服务器·数据库·笔记