Redis Sentinel 实战

2019-07-28  本文已影响0人  Cuccci
Sentinel(哨兵)模式是什么?

Sentinel(哨兵)是Redis高可用的解决方案,由一个或者多个Sentinel实例组成的Sentinel系统可以监视任意多个主服务器,以及这些主服务器属下的所有从服务器,并在被监视的主服务器进入下线状态时,自动将下线主服务器属下的某个从服务器升级为新的主服务器,然后由新的主服务器代替已下线的主服务器继续处理命令请求。

搭建 Redis Sentinel 环境
  1. 安装docker环境
    安装方法点击
  2. 获取Redis镜像
docker pull redis:5.0.5
  1. 新建外挂文件的挂载点
mkdir /usr/local/conf/redis-master
mkdir /usr/local/conf/redis-slave
mkdir /usr/local/conf/redis-sentinel

将配置文件 redis.confsentinel.conf放入到上面3个配置文件中

  1. 启动容器
docker run -d -p 6379:6379 -v /usr/local/conf/redis-master/redis.conf:/data/redis.conf --name redis-master redis:5.0.5 redis-server redis.conf

docker run -d -p 6380:6379 -v /usr/local/conf/redis-slave/redis.conf:/data/redis.conf --name redis-slave redis:5.0.5 redis-server redis.conf
  1. 配置从节点
docker container inspect redis-master
redis-master容器信息
docker exec -it redis-slave redis-cli
SLAVEOF 172.17.0.2 6379
  1. 配置哨兵节点


    sentinel.conf

    将配置文件的127.0.0.1改成对应的master的ip本文中为:172.17.0.2
    将配置文件的2改成1(需要多少个哨兵投票同意可以使slave转成master)
    启动哨兵节点

docker run -d -p 26379:26379 -v /usr/local/conf/redis-sentinel/sentinel.conf:/data/sentinel.conf --name redis-sentinel redis:5.0.5 redis-sentinel sentinel.conf
哨兵.png
校验哨兵模式
  1. 查看各个节点的角色


    redis-master.png
redis-slave.png
  1. 关闭redis-master容器
docker container stop redis-master
redis-slave.png

可以看到redis-slave节点中的解决变成了master节点了

上一篇下一篇

猜你喜欢

热点阅读