Redis主从配置

转载请注明出处:

Redis主从配置的特点

  1. 数据同步:主库(Master)负责处理写请求,并将数据更改同步到从库(Slave)。从库主要用于读请求和数据备份。
  2. 读写分离:通过配置从库为只读,可以有效分散读请求,提升系统性能。
  3. 高可用性和容错:即使主库出现故障,从库也能继续提供读服务,并在主库恢复后重新同步数据。
  4. 可扩展性:支持一主多从以及多级从结构,可以根据需要扩展从库数量,提高系统读取能力和数据冗余度。
  5. 异步复制:主从同步是异步进行的,不会阻塞主库处理请求。

配置

在Redis中,主从配置主要通过修改配置文件(通常是redis.conf)来实现。以下是一些关键配置项:

  1. 主库配置
    • 无需特别配置即可作为主库使用,但需确保监听端口和绑定地址正确设置。
    • 可以选择关闭数据持久化(如RDB和AOF),以提高主库性能,但需注意数据安全性。
  2. 从库配置
    • slaveof <masterip> <masterport>:指定从库要复制的主库IP地址和端口号。
    • replica-read-only yes(Redis 5.0及以上版本中使用replicaof替代了slaveof,但效果相同):设置从库为只读模式。
    • 其他配置如日志、持久化等可根据需要进行调整。

主库配置文件(redis_master.conf)

复制代码
# 端口号  
port 6379  
  
# 启用守护进程模式  
daemonize yes  
  
# 日志文件位置  
logfile "/var/log/redis/redis-server.log"  
  
# 数据目录  
dir "/var/lib/redis"  
  
# 最大内存限制(根据需要调整)  
maxmemory 16gb  
  
# 数据持久化配置(此处以RDB为例,AOF可根据需要配置)  
save 900 1  
save 300 10  
save 60 10000  
  
# 其他配置...

从库配置文件(redis_slave.conf)

复制代码
# 端口号(与主库不同)  
port 6380  
  
# 启用守护进程模式  
daemonize yes  
  
# 日志文件位置  
logfile "/var/log/redis/redis-slave-server.log"  
  
# 数据目录  
dir "/var/lib/redis_slave"  
  
# 指定要复制的主库  
slaveof 192.168.1.100 6379  
  
# 设置为只读模式  
replica-read-only yes  
  
# 其他配置(如持久化、内存限制等可根据需要调整)  
# ...

注意:

  • 在实际部署时,需要将slaveof(或replicaof)指令中的IP地址和端口号替换为实际的主库地址和端口号。
  • 配置文件中的其他选项(如日志位置、数据目录、内存限制等)也应根据实际需求进行调整。
  • Redis的主从配置是异步的,因此在网络延迟较高或主库负载较重时,从库的数据可能会有一定的滞后。
  • 为了确保数据安全,建议同时配置RDB和AOF持久化机制,或者在从库上配置持久化而禁用主库的持久化功能。

命令查看主从角色

方式1:通过Info replication 命令进行查看

查看当前节点主从角色命令:

复制代码
INFO replication

在主节点上进行查看:

在备节点上进行查看:

方式2:通过role命令进行查看

在主节点上执行:

在从节点上执行:

相关推荐
z***3351 小时前
redis清理缓存
数据库·redis·缓存
麦兜*13 小时前
Redis内存消耗异常飙升?深入排查与Big Key/Hot Key的根治方案
jvm·数据库·spring boot·redis·spring·缓存
成为你的宁宁13 小时前
【Redis 从入门到实战:详细讲解 Redis 安装配置、RDB/AOF 数据持久化方案、一主两从同步部署,深入剖析哨兵模式工作原理与哨兵模式高可用全攻略】
数据库·redis·缓存
v***56513 小时前
使用bitnamiredis-sentinel部署Redis 哨兵模式
数据库·redis·sentinel
一叶飘零_sweeeet17 小时前
2025 年 Redis 面试天花板
redis·缓存·面试
d***93518 小时前
Redis五种用途
数据库·redis·缓存
爬山算法19 小时前
Redis(128)Redis的跳表(Skip List)是如何实现的?
数据库·redis·list
Unstoppable2220 小时前
八股训练营第 20 天 | MySQL和Redis的区别是什么?Redis有什么优缺点、为什么用Redis查询会比较快?
数据库·redis·mysql·八股
e***74951 天前
Redis——使用 python 操作 redis 之从 hmse 迁移到 hset
数据库·redis·python
q***d1731 天前
后端缓存技术学习资源,Redis+Memcached
redis·学习·缓存