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

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

相关推荐
杰克尼39 分钟前
MYSQL-175. 组合两个表
数据库·mysql
DemonAvenger41 分钟前
MySQL索引原理深度解析与优化策略实战
数据库·mysql·性能优化
189228048611 小时前
NY270NY273美光固态闪存NY277NY287
服务器·网络·数据库·科技·性能优化
星霜笔记5 小时前
Docker 部署 MariaDB+phpMyAdmin+Nextcloud 完整教程
运维·数据库·docker·容器·mariadb
wyiyiyi10 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
天宇_任11 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
鼠鼠我捏,要死了捏12 小时前
生产环境Redis缓存穿透与雪崩防护性能优化实战指南
redis·cache
xiep143833351014 小时前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
Java小白程序员14 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring
老虎062715 小时前
数据库基础—SQL语句总结及在开发时
数据库·sql·oracle