Redis —— 自动主从切换

        在一个主从系统中,如果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版权协议,转载请附上原文出处链接和本声明。