【Redis】Redis集群:Sentinel

Redis Sentinel基本原理

Redis提供的一种高可用方案:类似于监控器,当故障发生时可以自动进行主从切换(自动选择一个最优的从节点切换为主节点),一般由3-5个节点组成。

【Redis】Redis集群:Sentinel_第1张图片
客户端连接Redis集群时,会首先连接Redis Sentinel(如果有的话),再通过Sentinel查询主节点的地址进行连接。

若主节点因各种原因不可用时,一个从节点会被提升为新的主节点,其他从节点开始和新的主节点建立主从关系。而客户端重新向Sentinel查询最新主节点的地址进行连接。

而原先挂掉的主节点恢复后,变成从节点,与新的主节点建立主从关系。

Sentinel默认端口为26379,通过Sentinel对象的discover_master && discover_slaves方法可以发现主从地址。

消息丢失问题

Redis主从为异步复制。如果主节点挂掉时,还有大量数据未同步到从节点,那这部分数据就会丢失。

Sentinel无法保证数据完全不丢失,但通过配置项两个参数可以尽量限制主从延迟过大:

//至少一个从节点进行正常复制,否则他停止对外写服务
min-slaves-to-write 1 
//x秒内没有收到从节点反馈,则为异常
min-slaves-max-lag 10 

你可能感兴趣的:(Redis)