数据库---redis---缓存穿透,缓存击穿,缓存雪崩,缓存预热

2021/9/16 2:08:44

本文主要是介绍数据库---redis---缓存穿透,缓存击穿,缓存雪崩,缓存预热,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

缓存穿透,缓存击穿,缓存雪崩,缓存预热

  • 缓存处理流程
  • 缓存穿透
    • 解决
  • 缓存击穿
    • 解决
  • 缓存雪崩
    • 这个没有完美解决办法
  • 缓存预热

缓存处理流程

前台请求,后台先从缓存中取数据,取到直接返回结果,取不到时从数据库中取,数据库取到更新缓存,并返回结果,数据库也没取到,那直接返回空结果。
请添加图片描述

缓存穿透

缓存穿透是指缓存和数据库中都没有的数据,而用户不断发起请求
如发起为id为“-1”的数据或id为特别大不存在的数据。这时的用户很可能是攻击者,攻击会导致数据库压力过大。

解决

实际开发中使用情况,数据库中80%-85%都存放到redis缓存,解决缓存穿透问题,很多值都是设置为空的值(空字符串、空List、空对象),都写进去, 这样维护起来代码比较简单,5分钟后也会自动过期,后面再有非法请求,缓存还是能hold住的。

缓存击穿

缓存击穿是指缓存中没有但数据库中有的数据(一般是缓存时间到期)。
这时由于并发用户特别多,同时读缓存没读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大,造成过大压力。
和缓存穿透区别:缓存穿透一般传一个id,一般是恶意攻击,缓存击穿一般是确实访问量过大。

解决

1、设置热点数据永远不过期。
2、加互斥锁

缓存雪崩

缓存雪崩是指缓存数据大批量到过期时间,而查询数据量巨大,引起数据库压力过大甚至down机。
和缓存击穿不同的是,缓存击穿指并发查同一条数据,缓存雪崩是不同数据都过期了,很多数据都查不到从而查数据库。

这个没有完美解决办法

但可以分析用户行为,尽量让失效时间点均匀分布。
请添加图片描述

缓存预热

新的缓存系统没有任何缓存数据,在缓存重建数据的过程中,系统性能和数据库负载都不太好,所以最好是在系统上线之前就把要缓存的热点数据(如果所有都加载,那么启动就会太慢,还有一些不常访问的提前加载也很难访问)加载到缓存中,这种缓存预加载手段就是缓存预热。



这篇关于数据库---redis---缓存穿透,缓存击穿,缓存雪崩,缓存预热的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程