Redis主从复制配置全攻略

Redis 主从复制笔记

一、主从同步原理

  1. Slave 发起同步请求
    • Slave 节点向 Master 节点发送同步请求。
  2. 认证与开始同步
    • Slave 通过 Master 的认证后,开始同步流程。
  3. Master 生成 RDB 快照
    • Master 执行 bgsave,生成内存快照(RDB)并发送给 Slave。
    • 此过程为异步操作,Master 仍可处理写请求。
  4. Slave 清空数据并加载 RDB
    • Slave 收到 RDB 后,先清空自身数据,再加载 RDB 恢复数据。
  5. 增量数据同步
    • 在 RDB 生成和传输期间,Master 将新写入的数据缓存起来。
    • 通过 replicationFeedSlave 函数,将这些增量数据逐条发送给 Slave。

二、配置步骤

1. 主节点配置(redis-node1)

复制代码
vim /etc/redis/redis.conf

修改以下配置:

复制代码
bind * -::*
protected-mode no

重启服务:

复制代码
systemctl restart redis_6379.service

2. 从节点配置(redis-node2、redis-node3)

复制代码
[root@redis-node2 和node3 ~]vim /etc/redis/redis.conf

添加或修改:

复制代码
bind * -::*
protected-mode no
replicaof 172.25.254.10 6379   # 指定主节点 IP 和端口

重启服务:

复制代码
[root@redis-node2 和node3 ~]systemctl restart redis_6379.service

三、状态查看与测试

1. 查看主节点状态

bash

复制代码
[root@redis-node1 ~]# redis-cli
127.0.0.1:6379> info replication

示例输出:

复制代码
role:master
connected_slaves:2
slave0:ip=172.25.254.20,port=6379,state=online
slave1:ip=172.25.254.30,port=6379,state=online

2. 查看从节点状态

复制代码
redis-cli
127.0.0.1:6379> info replication

示例输出:

复制代码
role:slave
master_host:172.25.254.10
master_port:6379
master_link_status:up

四、数据同步测试

主节点写入数据

复制代码
redis-cli
127.0.0.1:6379> set name swp
OK
127.0.0.1:6379> get name
"swp"

从节点读取数据

复制代码
redis-cli
127.0.0.1:6379> get name
"swp"

从节点写入测试(应失败)

复制代码
127.0.0.1:6379> set test baibai
(error) READONLY You can't write against a read only replica.

说明:从节点默认只读,无法执行写操作。


五、注意事项

  • 主从复制是异步的,主节点不会等待从节点确认。
  • 从节点默认只读,可通过配置 replica-read-only no 关闭(不推荐)。
  • 若主节点无持久化配置,建议结合 requirepass 设置密码认证。
    认只读,无法执行写操作。

五、注意事项

  • 主从复制是异步的,主节点不会等待从节点确认。
  • 从节点默认只读,可通过配置 replica-read-only no 关闭(不推荐)。
  • 若主节点无持久化配置,建议结合 requirepass 设置密码认证。
  • 支持一主多从、链式复制(从节点也可作为其他从节点的主节点)。
相关推荐
cmes_love4 小时前
美股和港股的量化笔记-从下载逐笔tick到合成分钟
笔记·区块链
AwakeFantasy4 小时前
关于Codex中转站生图比例问题的解决记录
数据库·redis·缓存
tkevinjd4 小时前
事务、ACID与隔离
java·数据库·sql
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题 第91题】【Mysql篇】第21题:分布式锁的使用场景和原理?
java·数据库·分布式·mysql·面试
流星白龙4 小时前
【MySQL高阶】18.缓冲池页管理
数据库·windows·mysql
A_humble_scholar5 小时前
C++11 学习笔记:统一初始化、右值引用与完美转发
c++·笔记·学习
XZ-0700015 小时前
MySQL-前缀索引
数据库·mysql
magic_now5 小时前
Modbus RTU 与 TCP 学习笔记
笔记·学习·tcp/ip
轻闲一号机5 小时前
【语音】笔记
前端·笔记·算法
专注VB编程开发20年5 小时前
淘宝上架销售技巧:Excel管理系统开发 / VBA / ERP / OA办公管理
java·数据库·excel