redis---哨兵模式Sentinel

上次搭建了一主两从的Redis集群,来实现了一定程度上的高可用。相比一个单节点的Redis来说已经有了很大的提升。

但是这个集群还是有一些问题的,主节点宕机了,我们还是需要手动去把另一台从节点提升为主节点,这样就不能实现真正的高可用。那么有什么办法可以实现自动的故障转移呢?

就说到redis哨兵模式了。哨兵会以一个独立的进程运行在redis集群中,用来监控redis集群中的各个节点。它主要用来执行下面的几个功能,第一个是监控,通过不断地发送命令来检查Redis节点是否正常。第二个是通知,如果发现某个节点出了问题,那么哨兵就会通过发布订阅模式来通知其他节点。第三个就是自动故障转移。当主节点不能正常工作的时候,哨兵就会开始一个自动故障转移的操作。它会将一个从节点升级为新的主节点,然后再将其他从节点指向新的主节点。

首先需要在Redis集群中,添加一个哨兵节点。可以使用redis -sentinel命令来启动哨兵节点。这里需要添加一个配置文件,文件名为sentinel.conf。用vi

在里面添加如下配置。

monitor后面加上一个名字,这里的master就是要监控的主节点的名称可以自定义,后面加上主节点的IP地址和端口号,最后一个参数1,表示只需要一个哨兵节点同意

启动哨兵节点

可以看到一个运行在26379端口

然后我们来找到6379这个服务端ctrl+c把它停下来,模拟一下主节点宕机。

哨兵它监控到了6379,然后执行了自动的故障转移,那现在新的的主节点是6381

可以看到6381现在已经变成了master

从节点6380,它的主节点对应的变成了6381

最后需要提醒一下,哨兵本身也是一个进程,它自己也会有单节点故障的问题。所以一般在实际的生产环境,会使用三个哨兵节点来保证高可用。这三个哨兵节点会通过选举的方式来选出一个领导者,然后由领导者来监控其他节点。如果领导者挂了,那么其他哨兵节点会重新选举出一个领导者。这样就可以保证哨兵节点的高可用。

相关推荐
办公解码器1 小时前
Excel工作表打开一次后自动销毁文件,回收站中都找不到
数据库·excel
爬山算法2 小时前
Redis(127)Redis的内部数据结构是什么?
数据结构·数据库·redis
应用市场2 小时前
Qt QTreeView深度解析:从原理到实战应用
开发语言·数据库·qt
q***96582 小时前
Spring Data JDBC 详解
java·数据库·spring
Hello,C++!2 小时前
linux下libcurl的https简单例子
linux·数据库·https
合方圆~小文3 小时前
高性能20倍变焦球机转动功能监控设备
数据结构·数据库·数码相机·模块测试
q***58194 小时前
【SQL】MySQL中的字符串处理函数:concat 函数拼接字符串,COALESCE函数处理NULL字符串
数据库·sql·mysql
懒羊羊不懒@4 小时前
【MySQL | 基础】多表查询
数据库·sql·mysql
百***6974 小时前
redis 使用
数据库·redis·缓存
mit6.8244 小时前
[Column] 构建十亿/s级DB | 索引DB&RTDB | Kafka 为中心 | Rust 构建引擎
数据库