缓存穿透是指查询一个必定不存在的数据,因为缓存不命中,接着查询数据库也没法查询出结果,所以也不会写入到缓存中,这将会致使每一个查询都会去请求数据库,形成缓存穿透;后端
对全部可能查询的参数以hash形式存储,在控制层先进行校验,不符合则丢弃,从而避免了对底层存储系统的查询压力;缓存
当存储层不命中后,即便返回的空对象也将其缓存起来,同时会设置一个过时时间,以后再访问这个数据将会从缓存中获取,保护了后端数据源;并发
可是这种方法会存在两个问题:分布式
若是空值可以被缓存起来,这就意味着缓存须要更多的空间存储更多的键,由于这当中可能会有不少的空值的键;高并发
即便对空值设置了过时时间,仍是会存在缓存层和存储层的数据会有一段时间窗口的不一致,这对于须要保持一致性的业务会有影响。spa
缓存雪崩是指,因为缓存层承载着大量请求,有效的保护了存储层,可是若是缓存层因为某些缘由总体不能提供服务,因而全部的请求都会达到存储层,存储层的调用量会暴增,形成存储层也会挂掉的状况。线程
即便个别节点、个别机器、甚至是机房宕掉,依然能够提供服务,好比 Redis Sentinel 和 Redis Cluster 都实现了高可用。 orm
在缓存失效后,经过加锁或者队列来控制读数据库写缓存的线程数量。好比对某个key只容许一个线程查询数据和写缓存,其余线程等待。对象
能够经过缓存reload机制,预先去更新缓存,再即将发生大并发访问前手动触发加载缓存不一样的key,设置不一样的过时时间,让缓存失效的时间点尽可能均匀。
缓存并发是指,高并发场景下同时大量查询过时的key值、最后查询数据库将缓存结果回写到缓存、形成数据库压力过大
在缓存更新或者过时的状况下,先获取锁,在进行更新或者从数据库中获取数据后,再释放锁,须要必定的时间等待,就能够从缓存中继续获取数据。