首先我们要明白缓存在一定意义上提高了系统的效率,降低了后台服务的压力,在系统并发量大的情况下,极大地提高了数据的查询性能,如redis的查询性能可高达110000次/秒
下面主要有几种防止的方法,归纳如下:
- 对于热点数据不设置key过期时间或进行延期
- 对于访问量大的数据可设置多级缓存
- 可以利用布隆过滤器,防止恶意攻击不存在key造成缓存击穿,应用启动后将数据缓存到布隆过滤器中
- 我们可以设置分布式锁,当发现缓存失效时,并不会直接到数据库中查找数据,而是先获取分布式锁,由获取分布式锁的线程到数据库中查询并存放到缓存中
- 造成缓存击穿的原因大致有两点:
- 当缓存中的key失效的瞬间,有大量的key请求过来,直接打到数据库上
- 存在大量而已请求去访问不存在的key,导致缓存形同虚设。
如何防止缓存击穿和穿透
最新推荐文章于 2023-07-03 14:10:34 发布