服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Redis - Redis Sentinel的使用方法

Redis Sentinel的使用方法

2021-07-29 15:45AsiaYe Redis

这篇文章主要介绍了Redis Sentinel的使用方法,帮助大家更好的理解和学习使用Redis数据库,感兴趣的朋友可以了解下

1、sentinel monitor

用法:

?
1
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 

用法如下:

?
1
sentinel  down-after-milliseconds master-name  times

该参数表示超过了配置的时间,没有收到有效的回复,则判断sentinel节点不可达,其中time的单位是毫秒。其中master-name为sentinel节点的名称。

3、sentinel parallel-syncs

用法:

?
1
sentinel parallel-syncs master-name nums

4、sentinel failover-timeout

用法:

?
1
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

用法:

?
1
sentinel auto-pass master-name password

从节点sentinel上配置主节点的密码,从而保证可以和主节点进行通信

6、sentinel notification-scripts

用法:

?
1
sentinel notification-scripts master-name scripts-path

7、sentinel client-reconfig-scripts

用法:

?
1
sentinel client-reconfig-scripts master-name scripts-path

 在故障转移结束后,会触发对应路径的脚本,并向脚本发送故障转移结果的相关参数。例如配置邮件或者报警。

参数6和参数7中需要注意,配置的脚本必须有执行权限,同时必须包含shell脚本头,脚本的最大执行时间不能超过60s,不过在一般的线上环境,通常不会用这个参数来配置相关脚本。

redis sentinel同时监控多个redis节点

   这个还是比较简单的,只需要在sentinel的配置文件中写上多个节点的名称,其他参数也区分开来即可。例如:

?
1
2
3
4
5
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

展示所有被监控的主节点状态以及相关的统计信息

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
[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的从节点状态以及相关统计信息

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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和端口

?
1
2
3
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的使用的资料请关注服务器之家其它相关文章!

延伸 · 阅读

精彩推荐
  • RedisRedis集群的5种使用方式,各自优缺点分析

    Redis集群的5种使用方式,各自优缺点分析

    Redis 多副本,采用主从(replication)部署结构,相较于单副本而言最大的特点就是主从实例间数据实时同步,并且提供数据持久化和备份策略。...

    优知学院4082021-08-10
  • RedisRedis 6.X Cluster 集群搭建

    Redis 6.X Cluster 集群搭建

    码哥带大家完成在 CentOS 7 中安装 Redis 6.x 教程。在学习 Redis Cluster 集群之前,我们需要先搭建一套集群环境。机器有限,实现目标是一台机器上搭建 6 个节...

    码哥字节15752021-04-07
  • Redis关于Redis数据库入门详细介绍

    关于Redis数据库入门详细介绍

    大家好,本篇文章主要讲的是关于Redis数据库入门详细介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览...

    沃尔码6982022-01-24
  • Redisredis缓存存储Session原理机制

    redis缓存存储Session原理机制

    这篇文章主要为大家介绍了redis缓存存储Session原理机制详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪...

    程序媛张小妍9252021-11-25
  • Redis《面试八股文》之 Redis十六卷

    《面试八股文》之 Redis十六卷

    redis 作为我们最常用的内存数据库,很多地方你都能够发现它的身影,比如说登录信息的存储,分布式锁的使用,其经常被我们当做缓存去使用。...

    moon聊技术8182021-07-26
  • Redis如何使用Redis锁处理并发问题详解

    如何使用Redis锁处理并发问题详解

    这篇文章主要给大家介绍了关于如何使用Redis锁处理并发问题的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习...

    haofly4522019-11-26
  • Redis详解三分钟快速搭建分布式高可用的Redis集群

    详解三分钟快速搭建分布式高可用的Redis集群

    这篇文章主要介绍了详解三分钟快速搭建分布式高可用的Redis集群,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...

    万猫学社4502021-07-25
  • RedisRedis Template实现分布式锁的实例代码

    Redis Template实现分布式锁的实例代码

    这篇文章主要介绍了Redis Template实现分布式锁,需要的朋友可以参考下 ...

    晴天小哥哥2592019-11-18