Redis Sentinel的使用方法
1、sentinel monitor
用法:
sentinel monitor master-name ip port quorum
其中,master-name是主节点的名称,ip,port不用解释,是主节点的地址信息。
最后的quorum是判断主节点最终不可达所需要的票数。这个值越大,判断越可信,这个值越小,判断越不可信,一般这个数字取的是sentinel节点数目的一半+1.同时,该值还与sentinel节点的领导者选举有关,至少要有max(quorum,num (sentinel)/2+1)个节点参与选举,才能选出领导者sentinel,从而完成故障转换。例如有5个sentinel节点,quorum设置为4,那么num(sentinel)/2+1=3,max函数返回4,最少要有4个节点才可以进行领导者选举。
2、sentinel down-after-milliseconds
用法如下:
sentinel down-after-milliseconds master-name times
该参数表示超过了配置的时间,没有收到有效的回复,则判断sentinel节点不可达,其中time的单位是毫秒。其中master-name为sentinel节点的名称。
3、sentinel parallel-syncs
用法:
sentinel parallel-syncs master-name nums
4、sentinel failover-timeout
用法:
sentinel failover-timeout master-name times
failover-timeout通常翻译成故障转移超时时间(以下简称FT),但实际上它作用于故障转移的各个阶段。它的作用:
a、如果redis sentinel对一个主节点的额故障转移失败,那么下次在对该主节点做故障转移的起始时间是FT的2倍
b、对于新选出来的主节点,执行slaveof no one的时候(因为原来它是个从库),如果出现失败,当超过FT时,则故障转移失败。
c、选出新的主节点后,redis会在新主节点上执行info命令,如果执行时间超过FT时,则故障转移失败
d、如果其余从节点和新的主节点,在重新建立复制关系的时候,如果超过了FT的时间,那么故障转移失败。
5、sentinel auth-pass
用法:
sentinel auto-pass master-name password
从节点sentinel上配置主节点的密码,从而保证可以和主节点进行通信
6、sentinel notification-scripts
用法:
sentinel notification-scripts master-name scripts-path
7、sentinel client-reconfig-scripts
用法:
sentinel client-reconfig-scripts master-name scripts-path
在故障转移结束后,会触发对应路径的脚本,并向脚本发送故障转移结果的相关参数。例如配置邮件或者报警。
参数6和参数7中需要注意,配置的脚本必须有执行权限,同时必须包含shell脚本头,脚本的最大执行时间不能超过60s,不过在一般的线上环境,通常不会用这个参数来配置相关脚本。
Redis Sentinel同时监控多个Redis节点
这个还是比较简单的,只需要在sentinel的配置文件中写上多个节点的名称,其他参数也区分开来即可。例如:
sentinel monitor node1 IP1 port1 quorum1 sentinel client-reconfig-scripts node1 scripts-path1 -------- sentinel monitor node2 IP2 port2 quorum2 sentinel client-reconfig-scripts node2 scripts-path2
Redis Sentinel 动态配置调整
我们可以使用sentinel set param value的方法来动态的设置sentinel的参数,这里有几点需要注意:
1、sentinel set命令只对当前sentinel节点有效
2、sentinel set命令如果执行成功,会立即刷新配置文件,而不需要我们手动config rewrite
3、建议所有sentinel节点的配置尽可能一致,可以提高故障转移的有效性
4、sentinel对外不支持config命令
Redis Sentinel部署原则
a、sentinel节点不应该部署在一台物理机器上。这个比较容易理解
b、部署至少三个且奇数个sentinel节点。注意,这里的奇数个不是为了投票,而是因为偶数个和奇数个的投票效果一致,奇数个可以节省一个节点。
c、有条件的情况下,尽量使用sentinel节点和redis节点一对一的方式部署,不要使用同一套sentinel来管理多个redis主节点。
相关的sentinel API:
1、sentinel masters
展示所有被监控的主节点状态以及相关的统计信息
[root@VM_48_10_centos ~]# redis-cli -p 26379 127.0.0.1:26379> sentinel masters 1) 1) "name" 2) "mymaster" 3) "ip" 4) "127.0.0.1" 5) "port" 6) "6379" 7) "runid" 8) "2ba04c1d8f837f2e419f6f5390c0d5938a6895f4" 9) "flags" 10) "master" 11) "pending-commands" 12) "0" 13) "last-ping-sent" 14) "0" 15) "last-ok-ping-reply" 16) "377" 17) "last-ping-reply" 18) "377" 19) "down-after-milliseconds" 20) "30000" 21) "info-refresh" 22) "8296" 23) "role-reported" 24) "master" 25) "role-reported-time" 26) "170821848" 27) "config-epoch" 28) "0" 29) "num-slaves" 30) "2" 31) "num-other-sentinels" 32) "2" 33) "quorum" 34) "2" 35) "failover-timeout" 36) "180000" 37) "parallel-syncs" 38) "1"
2、sentinel master master-name
展示指定master-name的主节点状态以及相关的统计信息
3、sentinel slaves master-name
展示指定master-name的从节点状态以及相关统计信息
127.0.0.1:26379> sentinel slaves mymaster 1) 1) "name" 2) "127.0.0.1:6380" 3) "ip" 4) "127.0.0.1" 5) "port" 6) "6380" 7) "runid" ----------------省略------------ 2) 1) "name" 2) "127.0.0.1:6381" 3) "ip" 4) "127.0.0.1" 5) "port" 6) "6381" 7) "runid"
4、sentinel sentinels master-name
展示指定master-name的sentinel节点集合,不包含当前sentinel节点。
5、sentinel get-master-addr-by-name master-name
返回指定master-name的主节点的IP和端口
127.0.0.1:26379> sentinel get-master-addr-by-name mymaster 1) "127.0.0.1" 2) "6379"
6、sentinel reset pattern
sentinel对于符合pattern通配符风格的主节点配置进行重置,包含清除主节点的相关状态,重新发现从节点和sentinel节点等
7、sentinel failover master-name
对指定<master-name>的主节点进行强制故障转移,该命令在redis的日常运维中非常有用。
8、sentinel ckquorum master-name
检测当前可达的sentinel节点总数是否达到了quorum的个数,例如quorum的值为3,而当前的可达的sentinel节点个数为2,则无法进行故障转移,redis sentinel的高可用特性也将失去
9、sentinel flushconfig
将sentinel节点的配置强制刷到磁盘上,这个命令sentinel节点自身用的比较多,当配置文件丢失或者损坏时,该命令比较有用。
10、sentinel remove master-name
取消当前redis sentinel节点对于指定master-name主节点的监控。
11、sentinel monitor master-name ip port quorum
这个命令和配置文件中的配置是一样的,都是为了监控主节点。只不过这个是通过命令的形式监控的。
12、sentinel set master-name
动态修改sentinel节点的配置选项
13、sentinel is-master-down-by-addr
sentinel节点之间用来交换对主节点是否下线的判断,根据参数的不同,可以作为sentinel领导者选举的通信方式。
以上就是Redis Sentinel的使用方法的详细内容,更多关于Redis Sentinel的使用的资料请关注猪先飞其它相关文章!
相关文章
- 这篇文章主要介绍了Redis连接池配置及初始化实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-29
- 这篇文章主要介绍了详解如何清理redis集群的所有数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-18
详解redis desktop manager安装及连接方式
这篇文章主要介绍了redis desktop manager安装及连接方式,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...2021-01-15- 这篇文章主要介绍了浅谈redis key值内存消耗以及性能影响,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-07
- 最近在工作中遇到了一个问题,通过查找相关资料才得知原因是因为返回结果的问题,下面这篇文章主要给大家介绍了关于lua读取redis数据的null判断的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下...2020-06-30
- 这篇文章主要介绍了SpringBoot集成Redis实现消息队列的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-10
redis setIfAbsent和setnx的区别与使用说明
这篇文章主要介绍了redis setIfAbsent和setnx的区别与使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-08-04- 这篇文章主要介绍了Redis的Expire与Setex区别说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-15
- Redis 是一个开源、高性能的Key-Value数据库,被广泛应用在服务器各种场景中。本文介绍几个查看Redis内存信息的命令,包括常用的info memory、info keyspace、bigkeys等。...2021-01-15
- 在本篇文章里小编给大家整理的是关于Redis的持久化方案详解,有兴趣的朋友们可以参考下。...2021-01-15
JAVA中 redisTemplate 和 jedis的配合使用操作
这篇文章主要介绍了JAVA中 redisTemplate 和 jedis的配合使用操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-13- 这篇文章主要介绍了@CacheEvict + redis实现批量删除缓存方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-10-12
- 这篇文章主要介绍了redis 交集、并集、差集的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
解决redisTemplate中leftPushAll隐性bug的问题
这篇文章主要介绍了解决redisTemplate中leftPushAll隐性bug的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-13- 这篇文章主要介绍了Redis开启远程访问及密码的教程,文中给大家提到了Redis启动报错解决方法,需要的朋友可以参考下...2021-01-15
springboot +redis 实现点赞、浏览、收藏、评论等数量的增减操作
这篇文章主要介绍了springboot +redis 实现点赞、浏览、收藏、评论等数量的增减操作,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-01-15- 这篇文章主要介绍了Redis集群水平扩展、集群中添加以及删除节点的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-03-25
- 这篇文章主要给大家介绍了关于如何利用Redis如何实现自动补全功能的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-04-17
- 这篇文章主要介绍了Redis swap空间的使用示例,帮助大家更好的理解和学习使用Redis数据库,感兴趣的朋友可以了解下...2021-03-25
- pipeline 只是把多个redis指令一起发出去,redis并没有保证这些指定的执行是原子的;multi相当于一个redis的transaction的,保证整个操作的原子性,避免由于中途出错而导致最后产生的数据不一致。本文详细的介绍,感兴趣的可以了解一下...2021-06-02