Redis 缓存雪崩、缓存穿透、缓存击穿

Redis 是一种常用的内存缓存工具,但在某些情况下,它可能会遭受缓存雪崩、缓存穿透和缓存击穿等问题。下面是一些预防这些问题的建议:

1、缓存雪崩

Redis 缓存雪崩、缓存穿透、缓存击穿_第1张图片

缓存雪崩指的是在某个时间点上,大量的缓存数据同时失效或过期,导致大量请求落到后端数据库上,引起系统崩溃。预防措施如下:

Redis 缓存雪崩、缓存穿透、缓存击穿_第2张图片

  • 逐级设置过期时间,避免所有缓存同时失效。

  • 设置随机过期时间,避免同时失效。

  • 引入限流和熔断机制,避免并发请求过多。

2、缓存穿透

Redis 缓存雪崩、缓存穿透、缓存击穿_第3张图片

缓存穿透指的是缓存中没有但数据库中有的数据,每次请求都会穿透缓存,直接请求数据库。攻击者可利用此漏洞进行攻击。预防措施如下:

Redis 缓存雪崩、缓存穿透、缓存击穿_第4张图片

  • 空值缓存:将查询结果为空的键也存储到缓存中,避免重复查询数据库。

  • 对于不存在的数据,也要缓存,设置一个较短的过期时间,减轻数据库压力。

  • 对于非法的请求参数,提前过滤掉,避免浪费资源。

  • 布隆过滤器:BloomFilter等布隆过滤器工具对请求进行过滤,判断请求的key是否合法,提前阻止非法请求。

3、缓存击穿

Redis 缓存雪崩、缓存穿透、缓存击穿_第5张图片

缓存击穿指的是某个热点key在缓存失效的短时间内,有大量的请求落到数据库上,引起数据库压力过大。预防措施如下:

Redis 缓存雪崩、缓存穿透、缓存击穿_第6张图片

  • 通过加锁,只允许一个请求查询数据库,其他请求等待查询结果。互斥锁,在缓存失效时,使用互斥锁来避免多个请求同时访问数据库。

  • 对于热点数据,设置永不过期,避免在高并发情况下,同时失效。

你可能感兴趣的:(面试必备知识,缓存,redis,数据库)