Redis 双机部署 完整方案(两种架构,适配两台机器)

目录

一、架构选型(双机唯一可行方案)

二、部署拓扑

核心优势

三、关键配置

[1、Master 配置(机器 1 redis.conf)](#1、Master 配置(机器 1 redis.conf))

[2、Slave 配置(机器 2 redis.conf)](#2、Slave 配置(机器 2 redis.conf))

[3、双哨兵配置(两台 sentinel.conf 都配置)](#3、双哨兵配置(两台 sentinel.conf 都配置))

四、启动顺序(严格按顺序)

五、故障模拟验证

六、业务连接写法

七、重要禁忌

八、极简总结


先明确:原生 Redis Cluster 集群不能双机做高可用 (最少 3 主),双机只能用「主从 + 哨兵」架构,是企业双机标准方案。

一、架构选型(双机唯一可行方案)

两台服务器:

  • 节点 A:主节点 Master
  • 节点 B:从节点 Slave + 哨兵
  • 两台都部署 Sentinel 哨兵

架构:1 主 1 从 + 双哨兵✅ 支持自动故障转移、主从切换、高可用❌ 不是 Redis-Cluster 分片集群(无哈希槽、不分片)


二、部署拓扑

复制代码
机器1(10.0.0.1):
  Redis-Master  + Sentinel-1

机器2(10.0.0.2):
  Redis-Slave   + Sentinel-2

核心优势

  1. 刚好两台机器,满足等保 / 双机热备要求
  2. 主库宕机,从库自动升级为主库
  3. 故障恢复后自动重新加入集群
  4. 配置简单、运维成本低

三、关键配置

1、Master 配置(机器 1 redis.conf)

复制代码
port 6379
bind 0.0.0.0
daemonize yes
requirepass 123456
masterauth 123456

2、Slave 配置(机器 2 redis.conf)

复制代码
port 6379
bind 0.0.0.0
daemonize yes
requirepass 123456
masterauth 123456
# 指向主库
replicaof 10.0.0.1 6379

3、双哨兵配置(两台 sentinel.conf 都配置)

复制代码
port 26379
daemonize yes
# 监控主库,mymaster自定义名称,1=法定票数
sentinel monitor mymaster 10.0.0.1 6379 1
sentinel auth-pass mymaster 123456
# 主库多久失联判定下线
sentinel down-after-milliseconds mymaster 30000
# 故障转移超时
sentinel failover-timeout mymaster 60000

投票数填 1:双哨兵环境必须这样,否则无法达成选举


四、启动顺序(严格按顺序)

  1. 启动主库 redis(机器 1)
  2. 启动从库 redis(机器 2)
  3. 两台机器分别启动 sentinel
bash 复制代码
redis-sentinel /etc/redis/sentinel.conf

五、故障模拟验证

  1. 关闭机器 1 Redis
  2. 哨兵自动感知,机器 2 从库自动升为主库
  3. 业务切换新主节点写入
  4. 恢复机器 1 Redis,自动变为新主的从库

六、业务连接写法

业务直接连接哨兵,而非固定主从:

复制代码
sentinel://10.0.0.1:26379,10.0.0.2:26379/mymaster

自动获取当前真实主节点地址,无感切换。


七、重要禁忌

  1. 不要用 Redis Cluster 做双机Cluster 至少 3 主,双机强行部署会脑裂、集群不可用。
  2. ✅ 双机热备 = 主从 + 哨兵 标准方案
  3. 数据强一致:开启 replica-serve-stale-data no

八、极简总结

  • 双机不能用 Redis 集群 (Cluster)
  • 双机标准方案:1 主 1 从 + 双哨兵
  • 满足:双机部署、自动切换、高可用、生产可用
  • 适合:中小项目、数据库双机热备架构
相关推荐
scott.cgi12 小时前
Unity直接编译Java文件作为插件,导致失败的两个打包设置
java·unity·unity调用java·unity的java文件·unity的android插件·unity调用android·unity加载java代码
澈20716 小时前
C++并查集:高效解决连通性问题
java·c++·算法
2401_8734794018 小时前
运营活动被薅羊毛怎么防?用IP查询+设备指纹联动封堵漏洞
java·网络·tcp/ip·github
ShiJiuD66688899918 小时前
大事件板块一
java
摇滚侠18 小时前
@Autowired 和 @Resource 的区别
java·开发语言
郑寿昌18 小时前
边缘AI传感:架构革命与智能跃迁
架构
SeaTunnel18 小时前
(八)收官篇 | 数据平台最后一公里:数据集成开发设计与上线治理实战
java·大数据·开发语言·白鲸开源
吴声子夜歌19 小时前
Java——线程的基本协作机制
java·线程协作
谙弆悕博士19 小时前
【附C++源码】从零开始实现 2048 游戏
java·c++·游戏·源码·项目实战·2048
IPHWT 零软网络19 小时前
从 SIP 软交换到国密加密:OM1000‑A‑UC 国产化 IPPBX 的架构与实战价值
架构·信息与通信·信创·国产化·ippbx