容器化redis高可用方案

本文介绍了一个基于DockerCompose的Redis Sentinel方案,通过简单的YML配置即可快速部署包含主库、从库及哨兵节点的集群。项目利用官方Redis镜像搭建master-slave架构,并通过自定义sentinel镜像实现高可用监测。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

偶然看到一个GITHUB项目,提供了一套Docker Compose下的redis Sentinel方案。
项目地址https://github.com/AliyunContainerService/redis-cluster,应该是国人创建的。

具体说明readme中写的很明白了,yml内容如下:

master:
  image: redis:3
slave:
  image: redis:3
  command: redis-server --slaveof redis-master 6379
  links:
    - master:redis-master
sentinel:
  build: sentinel
  environment:
    - SENTINEL_DOWN_AFTER=5000
    - SENTINEL_FAILOVER=5000    
  links:
    - master:redis-master
    - slave 

master和slave使用redis官方镜像,slave为master的从库。
sentinel则为基于redis官方镜像的自定义镜像,并增加了sentinel配置文件和相关环境变量。

运行后,轻松获得三个容器,分别为redis主库、redis从库和sentinel。

73868-20160806234529231-799372905.png

扩展也非常方便,二行命令,轻松扩展成三个sentinel,两个从库。

73868-20160806234820278-702133194.png

爽完了之后,才发现还是有一大一小两个问题,
一大是应用从sentinel中的到的get-master-addr-by-name是容器中的内网地址和端口。。。容器外没办法访问。只能将应用放在docker compose容器中external_links此容器才行。
一小是sentinel镜像是基于redis镜像的,也会监听6379端口提供redis服务,貌似有点浪费了。

转载于:https://www.cnblogs.com/lazio10000/p/5745217.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值