Redis 缓存如何出错?

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

缓存系统如何出错?

下图显示了缓存可能出错的 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. 为高速缓存建立一个集群,以提高高速缓存的可用性。
责任编辑:武晓燕 来源: ByteByteGo
相关推荐

2019-06-19 15:54:12

Redis缓存内存

2018-09-12 19:46:53

数据库MySQLRedis

2019-10-12 14:19:05

Redis数据库缓存

2023-03-10 13:33:00

缓存穿透缓存击穿缓存雪崩

2018-12-13 12:43:07

Redis缓存穿透

2021-06-05 09:01:01

Redis缓存雪崩缓存穿透

2023-10-04 19:43:38

2022-03-08 00:07:51

缓存雪崩数据库

2015-04-22 14:41:04

云迁移Redis缓存数据模型调整

2023-04-14 07:34:19

2020-03-16 14:57:24

Redis面试雪崩

2024-04-08 11:25:10

Redis缓存策略

2024-01-08 09:43:20

2023-09-24 14:35:43

Redis数据库

2023-12-06 13:38:00

Redis缓存穿透缓存击穿

2021-08-05 16:10:03

进程缓存缓存服务Java

2020-07-11 09:25:15

Python编程语言代码

2024-01-10 14:45:46

Redis数据库存储

2020-01-10 15:42:13

SpringBootRedis数据库

2023-01-31 08:37:11

缓存穿透击穿
点赞
收藏

51CTO技术栈公众号