zoukankan      html  css  js  c++  java
  • java使用Redis6--sentinel单点故障主从自动切换

    Redis Sentinel
    Sentinel(哨兵)是用于监控redis集群中Master状态的工具,其已经被集成在redis2.4+的版本中

    一、Sentinel作用:
    1):Master状态检测 
    2):如果Master异常,则会进行Master-Slave切换,将其中一个Slave作为Master,将之前的Master作为Slave
    3):Master-Slave切换后,master_redis.conf、slave_redis.conf和sentinel.conf的内容都会发生改变,即master_redis.conf中会多一行slaveof的配置,sentinel.conf的监控目标会随之调换
    二、Sentinel工作方式:
    1):每个Sentinel以每秒钟一次的频率向它所知的Master,Slave以及其他 Sentinel 实例发送一个 PING 命令
    2):如果一个实例(instance)距离最后一次有效回复 PING 命令的时间超过 down-after-milliseconds 选项所指定的值, 则这个实例会被 Sentinel 标记为主观下线。
    3):如果一个Master被标记为主观下线,则正在监视这个Master的所有 Sentinel 要以每秒一次的频率确认Master的确进入了主观下线状态。
    4):当有足够数量的 Sentinel(大于等于配置文件指定的值)在指定的时间范围内确认Master的确进入了主观下线状态, 则Master会被标记为客观下线
    5):在一般情况下, 每个 Sentinel 会以每 10 秒一次的频率向它已知的所有Master,Slave发送 INFO 命令
    6):当Master被 Sentinel 标记为客观下线时,Sentinel 向下线的 Master 的所有 Slave 发送 INFO 命令的频率会从 10 秒一次改为每秒一次
    7):若没有足够数量的 Sentinel 同意 Master 已经下线, Master 的客观下线状态就会被移除。 
    若 Master 重新向 Sentinel 的 PING 命令返回有效回复, Master 的主观下线状态就会被移除。

    主观下线和客观下线
    主观下线:Subjectively Down,简称 SDOWN,指的是当前 Sentinel 实例对某个redis服务器做出的下线判断。
    客观下线:Objectively Down, 简称 ODOWN,指的是多个 Sentinel 实例在对Master Server做出 SDOWN 判断,并且通过 SENTINEL is-master-down-by-addr 命令互相交流之后,得出的Master Server下线判断,然后开启failover.

    SDOWN适合于Master和Slave,只要一个 Sentinel 发现Master进入了ODOWN, 这个 Sentinel 就可能会被其他 Sentinel 推选出, 并对下线的主服务器执行自动故障迁移操作。
    ODOWN只适用于Master,对于Slave的 Redis 实例,Sentinel 在将它们判断为下线前不需要进行协商, 所以Slave的 Sentinel 永远不会达到ODOWN。

    三、配置:
    1:指定监听Master(三个节点)
    # vi /main/redis/sentinel26379.conf

    port 26379
    dir "/tmp"
    #shard1
    sentinel monitor shard1 192.168.77.135 6379 2
    sentinel down-after-milliseconds shard1 30000
    sentinel parallel-syncs shard1 1
    sentinel failover-timeout shard1 180000


    #上面配置文件说明如下:
    #第一行指定sentinel端口号
    #第二行指定sentinel为后台启动
    #第三行指定Sentinel去监视一个名为 mymaster 的Master,Master的IP地址为192.168.100.211,端口号为6379,最后的2表示当有2个Sentinel检测到Master异常时才会判定其失效,即只有当2个Sentinel都判定Master失效了才会自动迁移,如果Sentinel的数量不达标,则不会执行自动故障迁移。
    #第四行指定Sentinel判定Master断线的时间。(单位为毫秒,判定为主观下线SDOWN)
    #第五行指定在执行故障转移时,最多可以有多少个Slave同时对新的Master进行同步。这个数字设置为1,虽然完成故障转移所需的时间会变长,但是可以保证每次只有1个Slave处于不能处理命令请求的状态

    sentinel26380.conf sentinel26381.conf修改端口即可


    2:启动sentinel(三个节点):

    启用master slave节点

    # /usr/redis/src/redis-sentinel /main/redis/sentinel26379.conf &

    # /usr/redis/src/redis-sentinel /main/redis/sentinel26380.conf &

    # /usr/redis/src/redis-sentinel /main/redis/sentinel26381.conf &
    四、注意点:
    1):首次启动时,必须先启动Master
    2):Sentinel 只在 server 端做主从切换,app端要自己开发(例如Jedis库的SentinelJedis,能够监控Sentinel的状态)
    3):若Master已经被判定为下线,Sentinel已经选择了新的Master,也已经将old Master改成Slave,但是还没有将其改成new Master。若此时重启old Master,则Redis集群将处于无Master状态,此时只能手动修改配置文件,然后重新启动集群

    五、java应用

    package redis;
    
    import java.util.HashSet;
    import java.util.Set;
    import redis.clients.jedis.HostAndPort;
    import redis.clients.jedis.Jedis;
    import redis.clients.jedis.JedisSentinelPool;
    public class MyJedisSentinelTest {
        @SuppressWarnings({ "rawtypes", "unchecked", "deprecation" })
        public static void main(String[] args) {
            Set sentinels = new HashSet();
            sentinels.add(new HostAndPort("192.168.77.135", 26379).toString());
            sentinels.add(new HostAndPort("192.168.77.135", 26380).toString());
            sentinels.add(new HostAndPort("192.168.77.135", 26381).toString());
            JedisSentinelPool sentinelPool = new JedisSentinelPool("shard2", sentinels);
            System.out.println("Current master: " + sentinelPool.getCurrentHostMaster().toString());
            Jedis master = sentinelPool.getResource();
            master.set("username","liangzhichao1");
            sentinelPool.returnResource(master);
            Jedis master2 = sentinelPool.getResource();
            String value = master2.get("username");
            System.out.println("username: " + value);
            master2.close();
            sentinelPool.destroy();
        }
    }
  • 相关阅读:
    setTimeout,setInterval你不知道的…
    浏览器console的用法
    命题和命题的否定可以同时成立吗?
    Web云笔记--CSS
    dreamweaver代码提示失效
    游戏平台代表--PS4【推荐】
    Mac上好用的视频播放器有哪些?
    新浪博客“网络繁忙请稍后再试”
    人工智能成功识别“色情暴力”信息??…
    JS查错小工具-三生有幸【推荐】
  • 原文地址:https://www.cnblogs.com/yangmengdx3/p/4708427.html
Copyright © 2011-2022 走看看