课程名称:Java架构师-十项全能
课程章节:
缓存中间件的三大坑
主讲老师:
姚半仙
课程内容:
缓存三大坑:
缓存击穿、缓存雪崩、缓存穿透
解决方案:
调整缓存过期策略
初阶玩家:设置缓存永不过期
高阶玩家:读写分离架构-利用Canal做数据异构方案,做一个读写分离的架构,用缓存当做读库。
调整热点缓存策略
使用热点缓存库
使用互斥锁-mutex
初阶玩家:到期上锁
高阶玩家:提前上锁,然后做异步缓存刷新,刷新完成后,将锁取消
解决方案:
调整缓存过期策略
初阶玩家:设置缓存永不过期
高阶玩家:读写分离架构-利用Canal做数据异构方案,做一个读写分离的架构,用缓存当做读库。
过期时间散列-过期时间由基础时间+动态散列时间(1-10分钟随机的时间),将过期时间分散开来,不会产生集中过期的现象。
缓存预热,在业务正式开始之前把缓存构建起来。
黑客使用不存在P03商品请求数据,由于缓存不存在,将直接查询数据库,由于数据库也不存在, 所有的巨量的P03商品的请求都将请求到数据库,将数据库打崩
解决方案:
数据不存在时,也可以在缓存中构建key-value,key有值,value为空的缓存
布隆过滤器:hash散列技术判断当前查询请求是否存在后端数据库中的方案。
高阶玩家:进击版布隆过滤器。
打开App,阅读手记