前台请求,后台先从缓存中取数据,取到直接返回结果,取不到时从数据库中取,数据库取到更新缓存,并返回结果,数据库也没取到,那直接返回空结果。
缓存穿透是指缓存和数据库中都没有的数据,而用户不断发起请求。
如发起为id为“-1”的数据或id为特别大不存在的数据。这时的用户很可能是攻击者,攻击会导致数据库压力过大。
实际开发中使用情况,数据库中80%-85%都存放到redis缓存,解决缓存穿透问题,很多值都是设置为空的值(空字符串、空List、空对象),都写进去, 这样维护起来代码比较简单,5分钟后也会自动过期,后面再有非法请求,缓存还是能hold住的。
缓存击穿是指缓存中没有但数据库中有的数据(一般是缓存时间到期)。
这时由于并发用户特别多,同时读缓存没读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大,造成过大压力。
和缓存穿透区别:缓存穿透一般传一个id,一般是恶意攻击,缓存击穿一般是确实访问量过大。
1、设置热点数据永远不过期。
2、加互斥锁
缓存雪崩是指缓存数据大批量到过期时间,而查询数据量巨大,引起数据库压力过大甚至down机。
和缓存击穿不同的是,缓存击穿指并发查同一条数据,缓存雪崩是不同数据都过期了,很多数据都查不到从而查数据库。
但可以分析用户行为,尽量让失效时间点均匀分布。
新的缓存系统没有任何缓存数据,在缓存重建数据的过程中,系统性能和数据库负载都不太好,所以最好是在系统上线之前就把要缓存的热点数据(如果所有都加载,那么启动就会太慢,还有一些不常访问的提前加载也很难访问)加载到缓存中,这种缓存预加载手段就是缓存预热。