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 设置密码认证。
  • 支持一主多从、链式复制(从节点也可作为其他从节点的主节点)。
相关推荐
2501_930707784 分钟前
使用C#代码压平 PDF 表单字段
数据库·pdf·c#
m0_4708576412 分钟前
CSS如何实现Bootstrap进度条自定义动画_利用keyframe关键帧
jvm·数据库·python
treesforest15 分钟前
IP数据库下载完全指南:免费与商业IP定位库对比
网络·数据库·php
书语时18 分钟前
单体 MySQL 支撑业务的上限一般从哪里先触顶?如何论证瓶颈在 DB?
数据库·mysql
m0_6245785920 分钟前
SQL高效实现基于JOIN的交叉分析_多表关联实现多维统计
jvm·数据库·python
威联通网络存储21 分钟前
QNAP 闪存底座:制造企业 ERP 数据库容灾方案
数据库·python·制造
城数派22 分钟前
1958-2024年乡镇的逐月土壤湿度数据
数据库·arcgis·数据分析·excel
ReSearch22 分钟前
sfsEdgeStore:边缘计算时代的轻量级数据存储解决方案
数据库·后端·github
Mike117.29 分钟前
GBase 8a 宽表查询里的压缩和行存列取舍
java·开发语言·数据库