zoukankan      html  css  js  c++  java
  • 容器化redis高可用方案

    偶然看到一个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。

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

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

  • 相关阅读:
    小程序自定义组件(3)子向父传参
    postgresql插件安装
    二进制减法的实现
    mysql锁表问题
    mysql查看修改参数
    众数问题-找出超过一半的数
    只出现一次的数
    元素最大间距离
    第一个缺失数字
    局部最小值位置
  • 原文地址:https://www.cnblogs.com/lazio10000/p/5745217.html
Copyright © 2011-2022 走看看