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
相关推荐
倔强的石头_7 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3169353811833 天前
Java连接Redis
redis
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神4 天前
三、用户与权限管理
数据库·mysql
小小工匠5 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
麦聪聊数据5 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_5 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡5 天前
【MySQL数据库】数据类型与表约束
数据库·mysql