在一个主从系统中,如果mast挂了,整个服务就不可用了,需要我们手动去把slave升级。要是大半夜的master挂了,难道要着急忙慌的去公司嘛?!达咩!!
sentinel哨兵
什么是哨兵
Redis Sentinel是一个分布式系统,在一个架构中运行着多个sentinel进程,这些进程使用流言协议来接收主服务器是否下线的信息。使用投票协议来决定是否执行自动故障迁移,以及选择哪一个从服务器作为新的主服务器。Redis Sentinel衍生出一个单独的可执行的文件—— redis-sentinel实际上它只是一个运行在特殊模式下的Redis服务器。在启动一个普通的Redis服务器时通过给定 --sentinel 选项来启动Redis Sentinel
自动主从切换过程
1. sentinel通过监控发现master挂了
主观和客观下线
- 主观下线:哨兵每秒向节点ping,如果在一定时间内没有回复,说明节点挂了。
- 客观下线:这个哨兵去询问其他哨兵,这个节点是不是真的挂了。需要经过几个哨兵的同意才能说明时真的挂了。
- 相关配置
- down-after-milliseconds 主观下线判断时间,默认30s
- sentinel monitor redis-master-name 主机ip 端口 数量
2. 升级从节点作为新的master
Question:谁选从节点?选哪个从节点?
- 先选哨兵(raft思想):先到先得,少数服从多数。先发现master挂的哨兵先去拉票,其他哨兵等着,每个哨兵只有一张票。最后少数服从多数(一半以上,所以我们在部署sentinel的时候最好是奇数台),选出哨兵。
- 再选从节点
- 断开连接时长(断开的时间越久,优先级越低)
- 优先级排序(redis.conf中的配置:replica-priority 100 (默认是100))
- 复制数量(从主节点同步的数据量大小)
- 如果前面因素都一样,那就根据进程ID
版权声明:本文为m0_37998944原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。