一、Redis哨兵模式
主从复制解决了数据备份的问题,但是如果主节点宕机,仍需要运维手动进行主从切换。要在主从复制下实现故障恢复的自动化,就需要使用Redis的哨兵(Sentinel)模式。
哨兵是一个独立于数据服务器的进程,用于监控redis数据服务器的状态,当主从模式下最关键的主服务器出现故障时,能够被哨兵自动的察觉。同时哨兵会在剩余的从服务器中"选举"出新的主服务器,达到自动化恢复系统服务的目的。
哨兵本身也要考虑单点故障的问题,所以Redis Sentinel一般由3~5个节点组成,这样即使挂了个别哨兵节点,哨兵整体还可以正常工作。
客户端来连接集群时,会首先连接 sentinel,通过 sentinel 来查询主节点的地址,然后再去连接主节点进行数据交互。当主节点发生故障时,客户端会重新向 sentinel 要地址,sentinel 会将最新的主节点地址告诉客户端。如此应用程序将无需重启即可自动完成节点切换。
切换过程:
可以看到主节点挂掉了,原先的主从复制也断开了,客户端和损坏的主节点也断开了。从节点被提升为新的主节点,其它从节点开始和新的主节点建立复制关系。客户端通过新的主节点继续进行交互。
Sentinel 会持续监控已经挂掉了主节点。待它恢复后,原先挂掉的主节点现在变成了从节点,从新的主节点那里建立复制关系。
哨兵模式搭建
配置3个Redis(1主2从),1个哨兵
主:128
从:129
从:130
哨兵:131
配置哨兵
在Redis中复制出Sentinel.conf文件到131的/etc/redis下
编辑配置文件
配置多个哨兵
如果想要配置多个哨兵,复制出该文件并修改端口号即可
启动哨兵
测试
挂掉128主
哨兵自动选举另一个从为主
二、哨兵的SpringBoot配置
引入依赖
配置哨兵
在application.yml中配置
领取专属 10元无门槛券
私享最新 技术干货