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();

}

}

java redis 故障切换_java使用Redis6–sentinel单点故障主从自动切换相关推荐

  1. Linux企业化运维--(7)redis服务之redis配置及主从复制、主从自动切换、集群、redis+mysql、gearman实现数据同步

    Linux企业化运维 实验所用系统为Redhat-rhel7.6. 目录 Linux企业化运维 Linux企业化运维--(7)redis服务之redis配置及主从复制.主从自动切换.集群.redis+ ...

  2. redis的主从自动切换

    设置redis主从主要是在不同的主机上编辑配置文件 我们准备三台主机 分别是server1.server2.server3 redis的主从自动切换是基于sentinel(哨兵) 1.Redis 的 ...

  3. php redis主从自动切换,Redis 集群的主从切换

    Redis 集群的主从切换不再使用 Sentinel 作为外置监控, 而是集群内部在主节点挂掉之后选举出一个从节点取代主节点, 处理相应的分片的数据请求. 当然前提条件是对应的主节点有至少一个可连通的 ...

  4. java redis 缓存_java实现redis缓存

    import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; im ...

  5. java redis服务_java链接redis服务器

    1.首先你需要下载驱动包jedis.jar确保下载最新驱动包. 2.public class RedisUtil { //服务器IP地址 private static String ADDR = &q ...

  6. java redis 网络断开_Redis长时间连接后自动断开

    从日志看2小时 [DEBUG] 22:02:48.206 org.nutz.ioc.impl.NutIoc.get(NutIoc.java:151) - Get 'emailAlertService' ...

  7. java 人脸检测_Java+OpenCV实现人脸检测并自动拍照

    java+opencv实现人脸检测,调用笔记本摄像头实时抓拍,人脸会用红色边框标识出来,并且将抓拍的目录存放在src下,图片名称是时间戳. 环境配置:win7 64位,jdk1.8 CameraBas ...

  8. java activemq 断线_java - 防止ActiveMQ重新连接失败时自动退出 - SO中文参考 - www.soinside.com...

    我有一个小型的spring-boot应用程序,该应用程序连接到ActiveMQ上的一个或多个主题,这些主题在启动时在应用程序的application.properties文件中设置-然后将这些消息发送 ...

  9. java redis 多节点,Redis单机多节点集群部署,超简单

    1.在虚拟机中部署具有三个主节点,三个从节点的集群(注,必须要有从节点),虚拟机的IP地址为192.168.133.129,三个主节点的部口号分别为7001(从:7004).7002(从:7005). ...

最新文章

  1. 网站被k不要慌,看看“老油条”们是怎么解决的吧!
  2. python教程:filter,map,reduce
  3. 解决Git中fatal: refusing to merge unrelated histories(亲测)
  4. Kafka 优化参数 unclean.leader.election.enable
  5. 英伟达数据中心业务营收不断创下新高,已连续9个财季保持增长
  6. 网络通信 public ip 和 private ip
  7. 【jQuery笔记Part2】01-jQuery显示隐藏切换动画侧边广告案例
  8. nodejs开发http接口
  9. 汉字笔顺动画技术剖析,android应用开发实战
  10. 【discuzX2】模板解析语法就template()函数分析
  11. 安卓虚拟机_安卓中的安卓虚拟机,那些闪退应用有救了
  12. java target文件夹_Maven不会创建“/ target / m2e-wtp / web-resources”文件夹
  13. ubuntu16 下安装 dnw 给开发板传输文件,出现的问题以及解决方法
  14. paddle.paramattr转换为torch框架下算法
  15. E聊SDK-简介(1): 介绍
  16. 【数据结构——图和图的存储结构】
  17. 驻云科技完成C轮近亿元融资 成为撬起云计算的“支点”
  18. 2018千峰PHP教程完整版
  19. 计算机主机降温,宁美国度教你电脑降温妙招
  20. 量子计算机 中国科学院,中科院量子计算机取得重大突破

热门文章

  1. 插件一:JAVA微信砍价活动源码分享[商品帮砍到0元,免费领取奖品]
  2. JEECG Online Coding 开发操作图解
  3. JSF 网站汇总(转)
  4. MySQL基础篇(06):事务管理,锁机制案例详解
  5. Markdown 基础语法与常见问题总结
  6. 数据仓库之电商数仓-- 3.3、电商数据仓库系统(DWT层)
  7. hadoop--hadoop集群常用脚本
  8. 基于Spring Cloud及K8S构建微服务应用
  9. Redis集群明细文档(转)
  10. Social Emotional Computing -价值观的运算