• Redis哨兵模式


    Master挂了,如何保证可用性,实现继续读写

    什么是哨兵

    Sentinel(哨兵)是用于监控Redis集群中Master状态的工具,是 Redis 高可用解决方案,哨兵可以监视一个或者多个redis master服务,以及这些master服务的所有从服务;当某个master服务宕机后,会把这个master下的某个从服务升级为master来替代已宕机的master继续工作。

    示例图

    图片描述

    配置哨兵监控master

    创建并且配置sentinel.conf:

    • 普通配置

      port 26379
      pidfile "/usr/local/redis/sentinel/redis-sentinel.pid"
      dir "/usr/local/redis/sentinel"
      daemonize yes
      protected-mode no
      logfile "/usr/local/redis/sentinel/redis-sentinel.log"
      
    • 核心配置

      # 配置哨兵
      sentinel monitor mymaster 127.0.0.1 6379 2
      # 密码
      sentinel auth-pass <master-name> <password>
      # master被sentinel认定为失效的间隔时间
      sentinel down-after-milliseconds mymaster 30000
      # 剩余的slaves重新和新的master做同步的并行个数
      sentinel parallel-syncs mymaster 1
      # 主备切换的超时时间,哨兵要去做故障转移,这个时候哨兵也是一个进程,如果他没有去执行,超过这个时间后,会由其他的哨兵来处理
      sentinel failover-timeout mymaster 180000
      

    启动哨兵 x 3

    redis-sentinel sentinel.conf

    测试

    1. master挂了,看slave是否成为master
    2. master恢复,观察slave状态

    结论

    master挂了以后,由于哨兵监控,剩余slave会进行选举,选举后其中一个成为master,当原来的master恢复后,他会成为slave。

     
  • 相关阅读:
    利用python 学习数据分析 (学习四)
    numpy 模块常用方法
    利用python 学习数据分析 (学习三)
    numpy 常用方法2
    瞎JB逆
    Codeforces 907 矩阵编号不相邻构造 团操作状压DFS
    AT Regular 086
    矩阵快速幂 求斐波那契第N项
    指数循环节(指数降幂)
    Educational Codeforces Round 32
  • 原文地址:https://www.cnblogs.com/wjx6270/p/13396318.html
Copyright © 2020-2023  润新知