Redis主从复制部署

目录

一、主节点(master)配置

1.修改主节点配置文件(redis.conf)

2.启动主节点并验证

二、从节点配置

1.修改从节点配置文件

2.启动从节点并验证

三、验证主从复制效果


一、主节点(master)配置

1.修改主节点配置文件(redis.conf)

bash 复制代码
# 编辑Redis配置文件(路径根据安装方式调整,通常为/etc/redis/redis.conf或/usr/local/redis/redis.conf)
vim /etc/redis/redis.conf

修改以下核心配置:

bash 复制代码
# 1. 绑定IP(允许从节点访问,可绑定内网IP或0.0.0.0)
bind 0.0.0.0

# 2. 保护模式关闭(否则从节点无法连接)
protected-mode no

# 3. 端口(默认6379,保持不变即可)
port 6379

# 4. 后台运行
daemonize yes

# 5. 日志文件(方便排查问题)
logfile "/var/log/redis/redis-master.log"

# 6. 持久化(可选,建议开启,避免主节点重启数据丢失)
appendonly yes
appendfilename "appendonly.aof"

# 7. 可选:设置密码(如果主节点有密码,从节点必须配置相同密码)
# requirepass "yourmasterpassword"

2.启动主节点并验证

bash 复制代码
# 启动主节点
redis-server /etc/redis/redis.conf

# 检查主节点状态(是否启动成功)
redis-cli ping
# 正常返回 PONG 则说明主节点启动成功

# 查看主节点角色(此时应为master)
redis-cli info replication
# 输出中会看到 role:master,connected_slaves:0

二、从节点配置

1.修改从节点配置文件

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

修改核心配置(基础配置同主节点,额外增加主节点关联配置):

bash 复制代码
# 基础配置(同主节点)
bind 0.0.0.0
protected-mode no
port 6379  # 单服务器模拟时改为6380
daemonize yes
logfile "/var/log/redis/redis-slave.log"
appendonly yes

# 关键:指定主节点信息
replicaof 192.168.1.100 6379  # Redis 5.x及以下用 slaveof,6.x+用 replicaof

# 若主节点设置了密码,需添加此行
# masterauth "yourmasterpassword"

# 从节点只读(默认开启,建议保持)
replica-read-only yes

2.启动从节点并验证

bash 复制代码
# 启动从节点
redis-server /etc/redis/redis.conf

# 检查从节点状态
redis-cli ping  # 返回 PONG 则启动成功

# 查看从节点复制状态
redis-cli info replication
# 输出中会看到:
# role:slave
# master_host:192.168.1.100
# master_port:6379
# master_link_status:up (up表示主从连接正常)

三、验证主从复制效果

bash 复制代码
# 1. 登录主节点,写入数据
redis-cli
127.0.0.1:6379> set test "master-slave-replication"
OK

# 2. 登录从节点,读取数据(能读到主节点写入的数据则复制生效)
redis-cli
127.0.0.1:6379> get test
"master-slave-replication"

# 3. 再次查看主节点的复制信息(connected_slaves会变为1)
redis-cli info replication
# 输出中 connected_slaves:1,且会显示从节点的IP和端口
相关推荐
KmSH8umpK13 分钟前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第五篇
数据库·redis·分布式
lilihuigz17 分钟前
企业培训网站搭建指南:5步在WordPress上创建品牌学院
数据库
WL_Aurora25 分钟前
MySQL 5 卸载到 MySQL 8 安装完整指南(不踩坑版)
数据库·mysql
灰阳阳28 分钟前
MySQL的基本架构
数据库·mysql·架构
AI进化营-智能译站1 小时前
ROS2 C++开发系列08-传感器数据缓存与指令解析方式之数组、向量与字符串实战
开发语言·c++·缓存·ai
@小柯555m1 小时前
MySql(高级操作符--Where in 和Not in)
数据库·sql·mysql
许彰午1 小时前
CacheSQL(一):手写数据库的工程化重生
java·数据库·缓存
MmeD UCIZ1 小时前
MySQL单表存多大的数据量比较合适
数据库·mysql
SarL EMEN1 小时前
mysql之联合索引
数据库·mysql
l1t1 小时前
DeepSeek总结的DuckDB anofox-forecast季节调整时间序列预测插件功能
开发语言·数据库