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 设置密码认证。
  • 支持一主多从、链式复制(从节点也可作为其他从节点的主节点)。
相关推荐
m0_613856292 小时前
Golang怎么实现测试跳过条件_Golang如何根据环境或条件跳过不适用的测试用例【操作】
jvm·数据库·python
csdn2015_2 小时前
修改分类信息的时候将分类异步写入redis
数据库·redis·bootstrap
STAT abil2 小时前
MySQL 的mysql_secure_installation安全脚本执行过程介绍
数据库·mysql·安全
SelectDB2 小时前
从 T+1 到分钟级:金城银行基于 Apache Doris 构建高可靠、强一致的实时数据平台
大数据·数据库·数据分析
abc123456sdggfd2 小时前
bootstrap如何修改输入框获取焦点时的光晕
jvm·数据库·python
woniu_buhui_fei2 小时前
Redis知识整理二
数据库·redis·缓存
qq_330037992 小时前
如何配置ASM元数据备份_md_backup与md_restore重建磁盘组结构
jvm·数据库·python
untE EADO2 小时前
redis的下载和安装详解
数据库·redis·缓存
海绵宝宝的月光宝盒2 小时前
2-非金属材料
经验分享·笔记·学习·其他·职场和发展·课程设计·制造