redis 哨兵模式的配置和使用
哨兵模式的原理
-
下线的判断 :
主观下线 : 指的是当前的哨兵 sentinel 对redis 的服务器做出的下线的判断
客观下线 :指的是多个哨兵得到redis服务器得到下线的结论, 指的是多个 Sentinel 实例在对Master Server做出 SDOWN 判断,并且通过 SENTINEL is-master-down-by-addr 命令互相交流之后,得出的Master Server下线判断,然后开启failover. -
原理
①每个Sentinel以每秒钟一次的频率向它所知的Master,Slave以及其他 Sentinel 实例发送一个 PING 命令 ;
②如果一个实例(instance)距离最后一次有效回复 PING 命令的时间超过 down-after-milliseconds 选项所指定的值, 则这个实例会被 Sentinel 标记为主观下线;
③如果一个Master被标记为主观下线,则正在监视这个Master的所有 Sentinel 要以每秒一次的频率确认Master的确进入了主观下线状态;
④当有足够数量的 Sentinel(大于等于配置文件指定的值)在指定的时间范围内确认Master的确进入了主观下线状态, 则Master会被标记为客观下线 ;(*客观下线后执行failover , 进行leader的选举 *
failover 操作 :
)
⑤在一般情况下, 每个 Sentinel 会以每 10 秒一次的频率向它已知的所有Master,Slave发送 INFO 命令
⑥当Master被 Sentinel 标记为客观下线时,Sentinel 向下线的 Master 的所有 Slave 发送 INFO 命令的频率会从 10 秒一次改为每秒一次 ;
⑦若没有足够数量的 Sentinel 同意 Master 已经下线, Master 的主观下线状态就会被移除;
若 Master 重新向 Sentinel 的 PING 命令返回有效回复, Master 的客观下线状态就会被移除;
- 配置
哨兵模式需要配置哨兵的配置文件!
-- 编辑 sentinel.conf
sentinel monitor mymaster 127.0.0.1 6379 1
-- 启动哨兵
redis-sentinel sentinel.conf
- 使用哨兵模式使用jedis
Set<String> set = new HashSet<>();
// set中放的是哨兵的Ip和端口
set.add("192.168.6.10:26379");
GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig();
// 使用哨兵模式 连接redis
JedisSentinelPool jedisSentinelPool = new JedisSentinelPool("mymaster", set, poolConfig, 60000);
Jedis jedis = jedisSentinelPool.getResource();
String value = jedis.get("k7");
jedis.set("Jedis", "Jedis");
System.out.println(value);
推荐阅读
-
Nginx服务器基本的模块配置和使用全攻略
-
Linux下进程管理工具Supervisor的安装配置和基本使用
-
JS中使用正则表达式g模式和非g模式的区别
-
Redis的使用--基本数据类型的操作命令和应用场景
-
Linux下SVN服务器同时支持Apache的http和svnserve独立服务器两种模式且使用相同的访问权限账号
-
AndroidStudio中ButterKnife 的配置和使用方法
-
Linux折腾记(八):使用GCC和GNU Binutils编写能在x86实模式运行的16位代码
-
php使用redis的几种常见操作方式和用法示例
-
基于scrapy的redis安装和配置方法
-
webpack-dev-server的配置和使用