• 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

  • 相关阅读:
    html中a标签的属性
    碳中和&专利创新专题:各省市县专利面板(原始文件)、低碳专利授权数等多指标数据
    EfficientFormer学习笔记
    shared_ptr共享的智能指针
    高级数据结构:最小生成树及普里姆算法
    基于Bootstarp+Html+Css的爱旅行网站设计
    Vue3计算属性
    Consummer<T>函数式接口中的andThen方法
    Golang中的类型转换介绍
    RK3588平台开发系列讲解(USB篇)内核 USB 配置
  • 原文地址:https://blog.csdn.net/m0_37998944/article/details/126062305