数据库---redis---缓存穿透,缓存击穿,缓存雪崩,缓存预热
2021/9/16 2:08:44
本文主要是介绍数据库---redis---缓存穿透,缓存击穿,缓存雪崩,缓存预热,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
缓存穿透,缓存击穿,缓存雪崩,缓存预热
- 缓存处理流程
- 缓存穿透
- 解决
- 缓存击穿
- 解决
- 缓存雪崩
- 这个没有完美解决办法
- 缓存预热
缓存处理流程
前台请求,后台先从缓存中取数据,取到直接返回结果,取不到时从数据库中取,数据库取到更新缓存,并返回结果,数据库也没取到,那直接返回空结果。
缓存穿透
缓存穿透是指缓存和数据库中都没有的数据,而用户不断发起请求。
如发起为id为“-1”的数据或id为特别大不存在的数据。这时的用户很可能是攻击者,攻击会导致数据库压力过大。
解决
实际开发中使用情况,数据库中80%-85%都存放到redis缓存,解决缓存穿透问题,很多值都是设置为空的值(空字符串、空List、空对象),都写进去, 这样维护起来代码比较简单,5分钟后也会自动过期,后面再有非法请求,缓存还是能hold住的。
缓存击穿
缓存击穿是指缓存中没有但数据库中有的数据(一般是缓存时间到期)。
这时由于并发用户特别多,同时读缓存没读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大,造成过大压力。
和缓存穿透区别:缓存穿透一般传一个id,一般是恶意攻击,缓存击穿一般是确实访问量过大。
解决
1、设置热点数据永远不过期。
2、加互斥锁
缓存雪崩
缓存雪崩是指缓存数据大批量到过期时间,而查询数据量巨大,引起数据库压力过大甚至down机。
和缓存击穿不同的是,缓存击穿指并发查同一条数据,缓存雪崩是不同数据都过期了,很多数据都查不到从而查数据库。
这个没有完美解决办法
但可以分析用户行为,尽量让失效时间点均匀分布。
缓存预热
新的缓存系统没有任何缓存数据,在缓存重建数据的过程中,系统性能和数据库负载都不太好,所以最好是在系统上线之前就把要缓存的热点数据(如果所有都加载,那么启动就会太慢,还有一些不常访问的提前加载也很难访问)加载到缓存中,这种缓存预加载手段就是缓存预热。
这篇关于数据库---redis---缓存穿透,缓存击穿,缓存雪崩,缓存预热的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24Redis资料:新手入门快速指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-07Redis高并发入门详解
- 2024-12-07Redis缓存入门:新手必读指南
- 2024-12-07Redis缓存入门:新手必读教程
- 2024-12-07Redis入门:新手必备的简单教程
- 2024-12-07Redis入门:新手必读的简单教程
- 2024-12-06Redis入门教程:从安装到基本操作
- 2024-12-06Redis缓存入门教程:轻松掌握缓存技巧