Redis脑裂问题详解及解决方案

Redis脑裂问题

Redis脑裂问题是指在主从集群中同时存在两个主节点,这会导致不同客户端往不同的主节点写入数据,最终导致数据不一致,甚至数据丢失。

哨兵主从集群脑裂

场景描述

假设有三台服务器:一台主服务器,两台从服务器,还有一个哨兵。当网络波动导致哨兵无法检测到主节点时,哨兵可能会通过选举将一个从节点提升为新的主节点。如果此时一些客户端仍连接到旧的主节点,而其他客户端连接到了新的主节点,就会出现脑裂问题。最终,恢复后的老主节点会被降级为从节点,并从新主节点同步数据,这期间写入旧主节点的数据会丢失。

解决方案

通过配置以下参数可以减少脑裂问题导致的数据丢失:

min-replicas-to-write 2
min-replicas-max-lag 10
  • min-replicas-to-write 2:要求至少有两个从节点才能进行写操作。
  • min-replicas-max-lag 10:从节点与主节点的复制延迟不能超过10秒。

配置这两个参数后,如果发生脑裂,原主节点会拒绝客户端的写入请求,从而避免大量数据丢失。

集群脑裂

Redis集群一般不会发生脑裂,因为集群通过过半选举机制来防止脑裂问题。每个Redis集群有16384个槽,任何一个槽没有指派到节点时,整个集群就会不可用。为了确保集群的稳定性,建议构建至少有3个主节点的集群,且主节点数量为奇数。

尽管如此,脑裂问题在分布式系统中依然不可完全避免,受限于CAP理论的制约。

多级缓存实例

一个使用了Redis集群和其他缓存技术的应用系统架构如下:

架构流程

  1. 负载均衡:用户请求通过负载均衡服务分发到Nginx上。负载均衡算法常用轮询或一致性哈希。
  2. Nginx本地缓存:Nginx应用服务器读取本地缓存(如Lua Shared Dict、Nginx Proxy Cache或本地Redis),如果命中则直接返回,提升整体吞吐量并减轻后端压力。
  3. 分布式缓存:若本地缓存未命中,则读取Redis分布式缓存集群(可采用主从架构提升性能和吞吐量)。若命中则返回数据,并回写到Nginx本地缓存。
  4. 回源到应用服务器:若Redis缓存未命中,则请求回源到Tomcat集群,尝试再读一次主Redis集群。
  5. Tomcat本地缓存:在Tomcat集群中,首先读取本地平台级缓存,若命中则返回并同步到主Redis集群。
  6. 数据库查询:所有缓存未命中时,查询数据库或其他服务获取数据并返回。

总结

该架构通过多级缓存机制提升系统性能:

  • Nginx本地缓存:解决热点数据缓存问题。
  • Redis分布式缓存:减少访问回源率。
  • Tomcat平台级缓存:防止缓存失效带来的冲击。
  • 数据库缓存:提升数据库查询效率。

多级缓存的使用保障了系统的高效性和稳定性。

相关推荐
Fly不安全19 分钟前
Web安全:缓存欺骗攻击;基于缓存、CDN的新型Web漏洞
nginx·web安全·缓存·web·cdn·缓存欺骗攻击
明月看潮生22 分钟前
青少年编程与数学 02-007 PostgreSQL数据库应用 11课题、视图的操作
数据库·青少年编程·postgresql·编程与数学
阿猿收手吧!30 分钟前
【Redis】Redis入门以及什么是分布式系统{Redis引入+分布式系统介绍}
数据库·redis·缓存
奈葵33 分钟前
Spring Boot/MVC
java·数据库·spring boot
落霞的思绪34 分钟前
Redis实战(黑马点评)——涉及session、redis存储验证码,双拦截器处理请求
spring boot·redis·缓存
leegong2311141 分钟前
Oracle、PostgreSQL该学哪一个?
数据库·postgresql·oracle
中东大鹅1 小时前
MongoDB基本操作
数据库·分布式·mongodb·hbase
夜光小兔纸1 小时前
Oracle 普通用户连接hang住处理方法
运维·数据库·oracle
Sunny_lxm1 小时前
<keep-alive> <component ></component> </keep-alive>缓存的组件实现组件,实现组件切换时每次都执行指定方法
前端·缓存·component·active
兩尛3 小时前
订单状态定时处理、来单提醒和客户催单(day10)
java·前端·数据库