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 分钟前
MySQL的表连接及案例演示
数据库·sql
光羽隹衡3 分钟前
SQL的导入导出数据和查询
数据库·sql
爱技术的阿呆3 分钟前
MySQL子查询及其案例
数据库·mysql
✿ ༺ ོIT技术༻17 分钟前
服务端高并发分布式结构演进之路
运维·服务器·redis·分布式·架构
..空空的人17 分钟前
C++基于protobuf实现仿RabbitMQ消息队列---技术认识2
服务器·数据库·c++·网络协议·gtest·异步·protobuf
小妖同学学AI24 分钟前
告别SQL编写!开源WrenAI实现自然语言与数据库的智能对话
数据库·sql·开源
风跟我说过她27 分钟前
基于Scrapy-Redis的分布式房产数据爬虫系统设计与实现
redis·分布式·爬虫·scrapy
DBA小马哥30 分钟前
PB级数据迁移挑战:Oracle故障响应优化实战
数据库·oracle
Logic10132 分钟前
《Mysql数据库应用》 第2版 郭文明 实验1 在MySQL中创建数据库和表核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
Haooog33 分钟前
Redis面试题(不定时更新)
数据库·redis·缓存·面试