企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
### 从节点的作用 * **从节点一般可以起到两个作用:** * **第一,**当主节点出现故障时,作为主节点的后备“顶”上来实现故障转移,Redis Sentinel已经实现了该功能的自动化,实现了真正的高可用 * **第二,**扩展主节点的读能力,尤其是在读多写少的场景非常适用,通常的模型如下图所示 ![](https://img.kancloud.cn/c0/4a/c04a69bdd21a5c61b27ad4b334bb4de5_712x614.png) **但上述模型中,从节点不是高可用的:** * 如果slave-1节点出现故障,首先客户端client-1将与其失联,其次Sentinel节点只会对该节点做主观下线,因为Redis Sentinel的故障转移是针对主节点的 * 所以很多时候,Redis Sentinel中的从节点仅仅是作为主节点一个热备,不让它参与客户端的读操作,就是为了保证整体高可用性,但实际上这种使用方法还是有一些浪费,尤其是在有很多从节点或者确实需要读写分离的场景,所以如何实现从节点的高可用是非常有必要的; ### Redis Sentinel读写分离设计思路 * Redis Sentinel在**对各个节点的监控中,如果有对应事件的发生,都会发出相应的事件消息**(详情见上面“Sentinel发布订阅频道”图片),**其中和从节点变动的事件有以下几个:** * **+switch-master:**切换主节点(原来的从节点晋升为主节点),说明减少了某个从节点 * **+convert-to-slave:**切换从节点(原来的主节点降级为从节点),说明添加了某个从节点 * **+sdown:**主观下线,说明可能某个从节点可能不可用(因为对从节点不会做客观下线),所以在实现客户端时可以采用自身策略来实现类似主观 下线的功能 * **+reboot:**重新启动了某个节点,如果它的角色是slave,那么说明添加了某个从节点 * **所以在设计Redis Sentinel的从节点高可用时,只要能够实时掌握所有从节点的状态,把所有从节点看做一个资源池**(如下图所示),无论是上线还是下线从节点,客户端都能及时感知到(将其从资源池中添加或者删除),这样从节点的高可用目标就达到了; ![](https://img.kancloud.cn/76/b5/76b5f66c070991f89b457748897f8bcd_731x671.png)