哨兵机制
有了主从,那我们需要对其进行监控,Sentinel会不断地检查你的主服务器和从服务器是否运作正常。某个节点故障后,Sentinel 会开始一次自动故障迁移操作, 它会将失效主服务器的其中一个从服务器升级为新的主服务器, 并让失效主服务器的其他从服务器改为复制新的主服务器; 当客户端试图连接失效的主服务器时, 集群也会向客户端返回新主服务器的地址, 使得集群可以使用新主服务器代替失效服务器。Redis Sentinel 是一个分布式系统, 你可以在一个架构中运行多个 Sentinel 进程(Progress), 这些进程使用流言协议(Gossip Protocols)来接收关于主服务器是否下线的信息, 并使用投票协议(Agreement Protocols)来决定是否执行自动故障迁移, 以及选择哪个从服务器作为新的主服务器。虽然 Redis Sentinel 释出为一个单独的可执行文件 redis-sentinel , 但实际上它只是一个运行在特殊模式下的 Redis 服务器。
本文件的配置文件及脚本在gitee上可查看 https://gitee.com/akonvm/redis-demo/tree/master/masterslave
sentinel是在主从模式上建立的,所有sentinel服务都监听master,它会自动检测到slave以及其它sentinel。所以主从搭建过程使用前一篇(Mac下搭建Redis5-主从模式)搭建好的服务即可,下面介绍在该主从架构上设置sentinel
1. 高可用架构图
图中实线标识需要在配置文件中指定的关系,虚线是自动检测到的关系
2. sentinel配置文件
redis解压目录下提供了sentinel的配置文件模块sentinel.conf
,将他拷贝过来修改即可
$ cd /Users/ankang/develop/redis-demo/masterslave/conf
$ cp /Users/ankang/develop/redis-5.0.7/sentinel.conf redis-sentinel-26379.conf
redis-sentinel-26379.conf
配置如下
# 关闭保护模式
protected-mode no
# 设定端口
port 26379
# 修改为守护模式,使之可以后台运行
daemonize yes
# 设置进程文件
pidfile "/var/run/redis-sentinel-26379.pid"
# 设置进日志文件
logfile "/Users/ankang/develop/redis-demo/masterslave/logs/redis-sentinel-26379.log"
# 哨兵sentinel监控的redis主节点的
## ip:主机ip地址
## port:哨兵端口号
## master-name:可以自己命名的主节点名字(只能由字母A-z、数字0-9 、这三个字符".-_"组成。)
## quorum:当这些quorum个数sentinel哨兵认为master主节点失联 那么这时 客观上认为主节点失联了
# sentinel monitor <master-name> <ip> <redis-port> <quorum>
sentinel monitor mymaster 127.0.0.1 6379 2
# 当在Redis实例中开启了requirepass <foobared>,所有连接Redis实例的客户端都要提供密码。
# sentinel auth-pass <master-name> <password>
sentinel auth-pass mymaster admin123
# master或slave多长时间(默认30秒)不能使用后标记为s_down状态。
sentinel down-after-milliseconds mymaster 5000
# 若sentinel在该配置值内未能完成failover操作(即故障时master/slave自动切换),则认为本次failover失败。
sentinel failover-timeout mymaster 10000
# myid在sentinel启动时会自动生成.多哨兵拷贝配置文件时不要拷贝该字段,需要删掉,否则故障切换不生效
# sentinel myid xxxxxxxxxxxxxx
redis-sentinel-26380.conf
、redis-sentinel-26381.conf
和redis-sentinel-26379.conf
基本一样,只需要修改文件中的port
、pidfile
、logfile
对应的端口
3. 添加启动脚本
在/Users/ankang/develop/redis-demo/masterslave/
目录下创建脚本redis-sentinel-26379.sh
、redis-sentinel-26380.sh
、redis-sentinel-26381.sh
。redis-sentinel-26379.sh
内容如下
#!/bin/sh
set -e
REDISPORT=26379
INSTALL_DIR="/Users/ankang/develop/redis-5.0.7"
DEMO_DIR="/Users/ankang/develop/redis-demo/masterslave"
EXEC="${INSTALL_DIR}/src/redis-sentinel"
CONF="${DEMO_DIR}/conf/redis-sentinel-${REDISPORT}.conf"
case "$1" in
start)
echo "Starting Redis sentinel..."
$EXEC $CONF
;;
stop)
pid=`ps aux | grep redis-sentinel | grep ${REDISPORT} | head -n 1 | awk '{print $2}'`
if [ -n "$pid" ]
then
echo "Stopping Redis sentinel[${pid}]..."
kill ${pid}
else
echo "Redis sentinel stopped"
fi
;;
*)
echo "Please use start or stop as first argument"
;;
esac
redis-sentinel-26380.sh
和redis-sentinel-26381.sh
可以拷贝redis-sentinel-26379.sh
,对应修改文件中的REDISPORT
变量的端口号即可
4. 启动与关闭
按下面命令执行
$ sh redis-sentinel-26379.sh start
$ sh redis-sentinel-26380.sh start
$ sh redis-sentinel-26381.sh start
注意:sentinel启动后,对应的配置文件会被自动修改
5. 故障迁移
这时关闭master服务,过一会其他的slave服务会自动切换为master,通过info
可查看。