使用缓存时,分布式环境下可能出现很多问题,下面我来说典型的三个
1.穿透

2.雪崩

3.击穿

4.总结
缓存穿透:查询一个数据库与缓存都永不存在的数据,导致每次都要查db
解决方法=》从db查出null结果也缓存,并加上短暂的过期时间
缓存雪崩:大面积缓存同时失效
解决方法=》缓存加过期时间时加随机值,别都加一样的,比如1-5分钟随机
缓存击穿:某一个缓存key,单点失效后,导致数据库被高并发请求同时访问
解决方法=》加锁,第一个请求进来时就加锁,后面的请求自然从缓存中能查到了
本文探讨了分布式缓存环境中常见的三大问题:缓存穿透、雪崩和击穿。缓存穿透指查询数据库和缓存都不存在的数据,解决办法是将空结果也缓存并设置短暂过期时间。缓存雪崩则是大量缓存同时失效,解决方案是在设置过期时间时加入随机值避免集体失效。缓存击穿是单个热点key失效导致数据库被高并发请求,可以通过加锁避免。这些策略有助于提升系统稳定性和性能。
使用缓存时,分布式环境下可能出现很多问题,下面我来说典型的三个
1.穿透

2.雪崩

3.击穿

缓存穿透:查询一个数据库与缓存都永不存在的数据,导致每次都要查db
解决方法=》从db查出null结果也缓存,并加上短暂的过期时间
缓存雪崩:大面积缓存同时失效
解决方法=》缓存加过期时间时加随机值,别都加一样的,比如1-5分钟随机
缓存击穿:某一个缓存key,单点失效后,导致数据库被高并发请求同时访问
解决方法=》加锁,第一个请求进来时就加锁,后面的请求自然从缓存中能查到了
286
547

被折叠的 条评论
为什么被折叠?