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

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

服务器之家 - 数据库 - Redis - Redis Sentinel的基本搭建

Redis Sentinel的基本搭建

2021-07-29 15:42AsiaYe Redis

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

redis sentinel的概念

 

   我们知道redis主从模式下,一旦主节点由于故障不能提供服务,需要人工将从节点晋升为主节点,同时还要通知应用方更新主节点的地址。然后在很多应用场景下这种故障处理的方式是无法接受的,应用程序需要实时感知当前的可用节点。为了解决这个问题,redis sentinel应运而生,也称之为"哨兵"。

   介绍sentinel之前,先来了解几个redis的概念,

主节点master:redis进程,主服务

从节点slave:redis进程,从服务

redis数据节点:主节点和从节点

sentinel节点:监控redis数据节点,独立的sentinel进程

sentinel节点集合:若干sentinel节点的抽象组合,若干sentinel节点进程

redis sentinel:redis高可用实现方案,sentinel节点集合和redis数据节点进程

01 主从复制问题

 

前面的文章中我们讲述了主从复制,可以将从节点作为主节点的灾备节点,今天我们来看主从复制带来的问题:

1、一旦主节点发生故障,从节点晋升为主节点的过程和应用调整新主节点的过程,都需要人为干预

2、主节点的写能力容易受到单机的限制

3、主节点的存储能力容易受到单机的限制

   一种常见的方法是使用脚本来触发主从节点的角色切换,例如在一个一主两从的结构中,假设主节点master,从节点slave1,slave2,我们来看故障发生时架构的状态:

1、主节点master故障,客户端连接失败,两个从节点复制失败

2、选择一个主节点slave1,对其执行slave of no one命令使其成为主节点master2

3、更新应用程序连接的节点为slave1的ip地址

4、slave2以slave1为新的主节点,复制slave1上的命令

5、待原来的master恢复之后,让它成为slave1的从节点。

上述过程可以做成自动化的过程,但是需要考虑三点:a、要确保判断节点不可达的机制健全,否则容易出现误判断情况

b、如果有多个从节点,如果保证只有一个从节点被晋升为主节点是个关键的问题

c、通知客户端新的主节点的机制是否足够健壮

02 redis sentinel的高可用机制

 

   sentinel能够自动完成故障发现和故障转移,并及时通知应用方。这是它的核心价值所在。

   redis sentinel是一个分布式架构,其中包含若干个sentinel和若干个redis数据节点,每个sentinel节点会对数据节点和其余sentinel节点进行监控,当它发现节点不可达时,会对节点做下线表示。如果被标识的是主节点,它还会和其他的sentinel进行协商,当大多数sentinel节点都认为主节点不可达时,他们会选举出来一个sentinel节点来实现故障自动转移,同时会将这个变化通知给redis应用方,整个过程是自动的,不需要人工介入。

redis sentinel与redis主从复制模式只是多了若干个sentinel节点,并没有对redis节点做特殊处理,这是很多redis开发和运维人员容易混淆的地方。

二者架构图如下:

Redis Sentinel的基本搭建

在整个主服务故障到重新选择主服务的过程中,sentinel主要干如下几件事情:

1、监控,sentinel节点会定期检测redis数据节点,其余sentinel节点是否可达

2、通知,sentinel节点会将故障转移的结果通知给应用方。

3、主节点故障转移:实现从节点晋升为主节点并维护后续正确的主从关系

4、配置提供者:在redis sentinel结构中,客户端在初始化的时候连接的是sentinel节点集合,从中获取主节点信息

   上面的架构图中不难发现sentinel也是多个的,这样的好处有两个:

1、可以保证sentinel的健壮性,一个sentinel挂了,不影响整个集群的功能。

2、对于节点的故障判断是多个sentinel同时判断出来的,有效的防止了误判

    sentinel节点本身其实就是独立的redis节点,只不过它们不存处数据,只支持部分命令。

    接下来,我们来看sentinel的部署和配置文件内容。

03 sentinel部署

 

    sentinel部署之前,需要先有master和两个slave的一主两从架构:

?
1
2
3
4
5
6
7
8
9
10
11
127.0.0.1:6379> info replication
# replication
role:master
connected_slaves:2
slave0:ip=127.0.0.1,port=6380,state=online,offset=169,lag=1
slave1:ip=127.0.0.1,port=6381,state=online,offset=169,lag=1
master_repl_offset:183
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:2
repl_backlog_histlen:182

  sentinel的部署配置文件:

?
1
2
3
4
5
6
[root@vm_48_10_centos redis]# cat redis-sentinel-26379.conf 
port 26379
daemonize yes
logfile "26379.log"
dir "/usr/local/redis-3.0.7"
sentinel monitor mymaster 127.0.0.1 6379 2

  其中,sentinel monitor mymaster代表sentinel要监控主节点6379,2代表判断主节点失败至少需要2个sentinel节点同意。

  其余两个sentinel的配置文件和这个大同小异,只需要修改对应端口和日志文件即可。sentinel启动命令如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
[root@vm_48_10_centos redis]# redis-sentinel redis-sentinel-26379.conf &
[1] 7311
[root@vm_48_10_centos redis]# redis-sentinel redis-sentinel-26380.conf &
[1] 7366
[root@vm_48_10_centos redis]# redis-sentinel redis-sentinel-26381.conf &
[2] 7380
[root@vm_48_10_centos redis]
[root@vm_48_10_centos redis]# ps -ef|grep sentinel
root      7312     1  0 22:51 ?        00:00:00 redis-sentinel *:26379 [sentinel]
root      7367     1  0 22:52 ?        00:00:00 redis-sentinel *:26380 [sentinel]
root      7381     1  0 22:52 ?        00:00:00 redis-sentinel *:26381 [sentinel]
root      7405  5850  0 22:52 pts/7    00:00:00 grep --color=auto sentinel

此时,重新查看26379这个sentinel的配置文件,会发现里面多了一些内容:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
[root@vm_48_10_centos redis]# cat redis-sentinel-26379.conf 
port 26379
daemonize yes
logfile "26379.log"
dir "/usr/local/redis-3.0.7"
sentinel monitor mymaster 127.0.0.1 6379 2
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
sentinel known-slave mymaster 127.0.0.1 6380
# generated by config rewrite
sentinel known-slave mymaster 127.0.0.1 6381
sentinel known-sentinel mymaster 127.0.0.1 26381 0a2c77616ef88282fa12ef7c8aca142a2473cd5a
sentinel known-sentinel mymaster 127.0.0.1 26380 3ad6460bf5f4b01f277fdce3aa423d596993eec5
sentinel current-epoch 0

   可以发现,sentinel之间已经进行了交互,并写入了配置文件中一些已经获取到的内容。

使用命令info sentinel查看当前sentinel集群的信息:

?
1
2
3
4
5
6
7
[root@vm_48_10_centos redis]# redis-cli -h 127.0.0.1 -p 26379 info sentinel
# sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
master0:name=mymaster,status=ok,address=127.0.0.1:6379,slaves=2,sentinels=3

以上就是redis sentinel的使用的详细内容,更多关于redis sentinel的资料请关注服务器之家其它相关文章!

原文链接:https://mp.weixin.qq.com/s/3ZTUWCi2wAfCJ97bdzco9Q

延伸 · 阅读

精彩推荐
  • RedisRedis Template实现分布式锁的实例代码

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

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

    晴天小哥哥2592019-11-18
  • Redisredis缓存存储Session原理机制

    redis缓存存储Session原理机制

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

    程序媛张小妍9252021-11-25
  • RedisRedis集群的5种使用方式,各自优缺点分析

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

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

    优知学院4082021-08-10
  • Redis关于Redis数据库入门详细介绍

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

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

    沃尔码6982022-01-24
  • Redis详解三分钟快速搭建分布式高可用的Redis集群

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

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

    万猫学社4502021-07-25
  • Redis《面试八股文》之 Redis十六卷

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

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

    moon聊技术8182021-07-26
  • RedisRedis 6.X Cluster 集群搭建

    Redis 6.X Cluster 集群搭建

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

    码哥字节15752021-04-07
  • Redis如何使用Redis锁处理并发问题详解

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

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

    haofly4522019-11-26