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

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

1、缓存雪崩

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

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

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

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

2、缓存穿透

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

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

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

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

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

3、缓存击穿

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

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

  • 对于热点数据,设置永不过期,避免在高并发情况下,同时失效。文章来源地址https://uudwc.com/A/MxR1J

原文地址:https://blog.csdn.net/LQ19900221/article/details/133067457

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

h
上一篇 2023年09月25日 10:40
一文读懂Llama 2(从原理到实战)
下一篇 2023年09月25日 10:40