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 设置密码认证。
  • 支持一主多从、链式复制(从节点也可作为其他从节点的主节点)。
相关推荐
ClouGence14 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将16 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_3 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
LinXunFeng3 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
用户3169353811836 天前
Java连接Redis
redis
倔强的石头_6 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence7 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle