目录
简介
Redis Sentinel即采用Sentinel得方案开启哨兵模式,在此模式下主redis服务崩溃其余从redis(哨兵)会随机选出一个转为主库,这样既可以保证安全性可靠性以实现高可用
为了方便我们采用docker容器来实现Sentinel哨兵
配置主从redis
首先拉取redis得镜像
$ docker pull redis
然后开动三个容器并开启端口映射这里我们用6379 6380 6381 三个端口
$ docker run --name redis-master -p 6379:6379 -d redis
$ docker run --name redis-slave1 -p 6380:6379 -d redis
$ docker run --name redis-slave2 -p 6381:6379 -d redis
然后查看主redis容器得内网IP地址
$ docker inspect redis-master
这里可以看到主redis容器得内网ip地址为172.17.0.2
一次查看其余内网地址为
172.17.0.3 172.17.0.4
然后进去从redis容器,打开redis客户端对redis进行配置
$ docker exec -it redis-slave1 /bin/bash
$ redis-cli
然后设置从redis容器的主redis容器目标为172.17.0.2 端口号为映射的端口号我们主容器映射的是6379
$ slaveof 172.17.0.2 6379
当显示OK时查看当前redis的角色和配置信息等
$ info replication
在这里可以看到配置信息无误,然后我们按同样的方法配置第二台从服务器
将从redis配置成sentinel哨兵
在各个从redis容器中的根目录
创建文件 sentinel.conf来设定哨兵
$ vim sentinel.conf
如果出现command not found错误按顺序运行以下命令这个错误是因为我们在docker的容器中是默认没有vim这个命令的这时候我们需要安装它
$ apt-get update
$ apt-get install vim
在 sentinel.conf文件中将主redis容器配置进去
sentinel monitor redis-master 172.17.0.2 6379 1
启动哨兵
$ redis-sentinel /sentinel.conf
在这里可以看到一些配置信息
同样的一次配置第二个从redis容器并启动,不过我们可以多开几个窗口方便测试和配置
测试
将主redis容器停止,然后进入任意一个从从redis容器并查看状态最后可以看到从redis容器的role变成了master
$ docker stop redis-master
//在从容器中
$ redis-cli
Info replication