Redis部署之哨兵

背景

在上篇中Redis部署之主从已完成redis主从部署,系统的性能提高了,但如果主节点发送故障,则无法对外提供写入服务,需要手动进行主从切换。

引入哨兵可提升系统可用性,并在主节点故障时自动完成主从切换。

环境说明

  • 2台云服务器
  • 使用docker部署
  • 一主一从一哨兵
  • redis版本为:7.2.4

前置条件

已完成redis主从部署

下载配置文件

shell 复制代码
wget http://download.redis.io/redis-stable/sentinel.conf

修改配置文件

shell 复制代码
# 哨兵监控IP为127.0.0.1端口号为6379的redis主服务器,主服务器名称为mymaster,最后的数字表示数量,例如3台哨兵,其中有2台哨兵认为redis主服务器已经宕机,则主机已经宕机,否则不认为redis的主服务器宕机
sentinel monitor mymaster 127.0.0.1 6379 2
# 在指定的毫秒数内,若主节点没有应答哨兵的 PING 命令,此时哨兵认为服务器主观下线,默认时间为 60 秒。
sentinel down-after-milliseconds mymaster 60000
# 如果主服务器配置了密码,则哨兵也必须配置密码,否则哨兵无法对主从服务器进行监控,该密码与主服务器密码一致
sentinel auth-pass mymaster 123456

如主节点配置了密码,则sentinel.conf配置文件必须配置密码,如:

sentinel auth-pass mymaster 123456

启动哨兵

shell 复制代码
docker run -d --name sentinel -p 26379:26379 -v /root/docker-data/redis/sentinel.conf:/usr/local/etc/redis/sentinel.conf -v /etc/localtime:/etc/localtime:ro redis redis-sentinel /usr/local/etc/redis/sentinel.conf

/root/docker-data/redis/sentinel.conf为宿主机挂载目录,可自行修改。

踩坑记录

在主从配置中,从节点需要连接主节点,因此从节点通过masterauth <your-password> 配置主节点认证密码从而连接主节点,而主节点不需要配置从节点的认证密码,因为不会自动进行主从切换,主节点不需要连接到从节点。

而在哨兵模式下,当主节点A下线,从节点B升级为主节点后,若A上线后,A会尝试以从节点的身份连接到主节点B,而由于A未配置从节点的认证密码,导致无法连接。

因此,哨兵模式下,主从节点都需要配置对方的认证密码,如:

shell 复制代码
masterauth 123456

参考文档

基于Docker搭建Redis一主两从三哨兵

Docker 部署Redis哨兵

相关推荐
小七-七牛开发者2 小时前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence7 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将10 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3169353811835 天前
Java连接Redis
redis
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle