Redis 缓存如何出错?
创始人
2025-07-11 07:11:04
0

缓存系统如何出错?

下图显示了缓存可能出错的 4 种典型情况及其解决方案。

01 雷群问题(Thurder Hurd)

当缓存中的大量 key 同时过期时,就会出现这种情况。然后,查询请求直接冲击数据库,导致数据库超载。

有两种方法可以缓解这一问题:

  1. 避免为 key 设置相同的过期时间,在配置中添加一个随机数;
  2. 只允许核心业务数据访问数据库,而在缓存恢复之前阻止非核心数据访问数据库。

02 缓存渗透(Cache Penetration)

当缓存或数据库中不存在 key 时,就会发生这种情况。应用程序无法从数据库中检索相关数据来更新缓存。这个问题给缓存和数据库都造成了很大的压力。

要解决这个问题,有两种建议。

  1. 为不存在的 key 缓存一个空值,避免对数据库造成冲击。
  2. 使用 bloom 过滤器先检查 key 是否存在,如果 key 不存在,我们就可以避免对数据库的访问。

03 缓存崩溃(Cache Breakdown)

这与雷群问题类似。它发生在热键过期时。大量请求会访问数据库。

解决方案:由于热键占据了 80% 的查询量,我们没有为它们设置过期时间。

04 缓存崩溃(Cache Crash)

当缓存崩溃时,所有请求都会进入数据库。

有两种方法可以解决这个问题。

  1. 设置断路器 (Circuit Breaker),当缓存宕机时,应用服务无法访问缓存或数据库。
  2. 为高速缓存建立一个集群,以提高高速缓存的可用性。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...