Redis主从复制:原理、配置与实战演示

📚 什么是Redis主从复制?

Redis主从复制(Master-Slave Replication)是一种数据冗余备份和高可用性解决方案 。它允许将一个Redis服务器(主节点)的数据自动同步到一个或多个Redis服务器(从节点)。

为什么需要主从复制?

  • 数据持久化保障:即使Redis服务重启,硬盘上的持久化数据可以恢复,但硬盘损坏仍会导致数据丢失

  • 避免单点故障:主从架构确保一台服务器宕机时,其他服务器可继续提供服务

  • 读写分离:主节点处理写操作,从节点处理读操作,提升系统性能

  • 数据备份:多个副本提供数据安全保障


🏗️ 主从复制架构图

一主两从架构

架构特点:

  • 主Redis中的数据有两个副本(从Redis1和从Redis2)

  • 即使一台Redis服务器宕机,其他两台仍可继续服务

  • 主Redis写入数据时,通过主从复制机制自动复制到所有从节点

主从级联架构

架构特点:

  • 一个Redis节点可以既是主又是从

  • 实现更灵活的数据同步拓扑

  • 减轻主节点的复制压力


🔄 核心特性

  1. 数据实时同步:主节点的数据变更实时同步到从节点

  2. 单一主节点:系统中只有一个主Redis,可配置多个从Redis

  3. 非阻塞复制:主从复制不会阻塞Master,同步期间Master仍可处理客户端请求

  4. 自动故障转移(结合哨兵模式):主节点故障时,从节点可自动升级为主节点


⚙️ 主从配置实战

环境准备

复制代码
主节点:192.168.0.209:6379
从节点:192.168.1.100:6380

主Redis配置(基本无需特殊配置)

复制代码
# redis-master.conf
bind 0.0.0.0
port 6379
requirepass 2020
daemonize yes

从Redis配置

复制代码
# redis-slave.conf
bind 0.0.0.0
port 6380
slaveof 192.168.0.209 6379  # 关键配置:指定主节点
masterauth 2020              # 主节点密码
requirepass 2020
daemonize yes
replica-read-only yes        # 从节点只读(默认)

配置说明:

  • slaveof:指定主Redis的IP和端口

  • masterauth:连接主节点所需的密码(如果主节点设置了密码)

  • replica-read-only:设置从节点为只读模式


🔧 配置步骤详解

步骤1:启动主节点

复制代码
redis-server /path/to/redis-master.conf

步骤2:启动从节点

复制代码
redis-server /path/to/redis-slave.conf

步骤3:验证主从状态

复制代码
# 检查主节点状态
redis-cli -p 6379 -a 2020 INFO replication

# 检查从节点状态  
redis-cli -p 6380 -a 2020 INFO replication

步骤4:测试数据同步

复制代码
# 在主节点写入数据
redis-cli -p 6379 -a 2020 SET demo_key "Hello Master-Slave"

# 在从节点读取数据
redis-cli -p 6380 -a 2020 GET demo_key
# 应返回:"Hello Master-Slave"

🔍 复制原理深入解析

全量复制流程

复制代码
1. 从节点连接主节点,发送SYNC命令
2. 主节点执行BGSAVE生成RDB快照
3. 主节点将RDB文件发送给从节点
4. 从节点清空旧数据,加载RDB文件
5. 主节点将缓冲区的写命令发送给从节点
6. 从节点执行这些命令,完成数据同步

部分复制机制(PSYNC)

复制代码
# 从节点发送PSYNC命令格式
PSYNC <master_runid> <offset>

参数说明:

  • master_runid:主节点标识,随机生成的40位字符串

  • offset:复制偏移量,标识数据同步位置

验证流程:

  1. 从机连接主机,发送PSYNC命令

  2. 主机验证runid和offset是否有效

  3. runid验证失败​ → 执行全量同步

  4. runid验证通过,offset有效​ → 执行部分同步

  5. runid验证通过,offset无效​ → 执行全量同步

复制积压缓冲区

主节点维护一个固定大小的复制积压缓冲区(replication backlog),用于保存最近的写命令。当从节点断线重连时:

  • 如果offset在缓冲区内 → 执行部分复制

  • 如果offset不在缓冲区内 → 执行全量复制

    配置积压缓冲区大小(默认1MB)

    repl-backlog-size 10mb

    配置缓冲区存活时间(默认1小时)

    repl-backlog-ttl 3600


⚠️ 常见问题与解决方案

问题1:主从连接失败

症状master_link_status:down

解决方案

复制代码
# 检查主节点配置
redis-cli -p 6379 CONFIG GET bind
redis-cli -p 6379 CONFIG GET protected-mode

# 从节点重新连接
redis-cli -p 6380 SLAVEOF NO ONE
redis-cli -p 6380 SLAVEOF 127.0.0.1 6379

问题2:认证失败

症状NOAUTH Authentication required

解决方案

复制代码
# 确保主从节点密码一致
# 主节点:requirepass 2020
# 从节点:masterauth 2020 和 requirepass 2020

问题3:同步延迟

症状:从节点数据落后主节点

解决方案

复制代码
# 调整复制参数
redis-cli -p 6379 CONFIG SET repl-backlog-size 10mb
redis-cli -p 6379 CONFIG SET repl-timeout 60
redis-cli -p 6379 CONFIG SET client-output-buffer-limit "slave 0 0 0"

通过主从复制,Redis实现了数据的多副本存储,为数据安全和系统高可用提供了坚实保障。

相关推荐
小陈工1 小时前
2026年4月2日技术资讯洞察:数据库融合革命、端侧AI突破与脑机接口产业化
开发语言·前端·数据库·人工智能·python·安全
IT_陈寒1 小时前
Vue的这个响应式问题,坑了我整整两小时
前端·人工智能·后端
C澒1 小时前
AI 生码:A 类生码方案架构升级
前端·ai编程
前端Hardy2 小时前
前端必看!LocalStorage这么用,再也不踩坑(多框架通用,直接复制)
前端·javascript·面试
前端Hardy2 小时前
前端必看!前端路由守卫这么写,再也不担心权限混乱(Vue/React通用)
前端·javascript·面试
Lee川2 小时前
从零构建现代化登录界面:React + Tailwind CSS 前端工程实践
前端·react.js
Awu12272 小时前
⚡精通 Claude 第 1 课:掌握 Slash Commands
前端·人工智能·ai编程
竹林8182 小时前
从ethers.js迁移到Viem:我在重构DeFi前端时踩过的那些坑
前端·javascript
码云之上2 小时前
上下文工程实战:解决多轮对话中的"上下文腐烂"问题
前端·node.js·agent
小小弯_Shelby2 小时前
webpack优化:Vue配置compression-webpack-plugin实现gzip压缩
前端·vue.js·webpack