为了账号安全,请及时绑定邮箱和手机立即绑定

【九月打卡】第14天 缓存中间件的三大坑

标签:
架构

课程名称Java架构师-十项全能

课程章节

缓存中间件的三大坑

主讲老师

姚半仙

课程内容

缓存三大坑:

缓存击穿、缓存雪崩、缓存穿透

 

https://img1.sycdn.imooc.com//63272d180001560b06180263.jpg

解决方案:

  1. 调整缓存过期策略

    1. 初阶玩家:设置缓存永不过期

    2. 高阶玩家:读写分离架构-利用Canal做数据异构方案,做一个读写分离的架构,用缓存当做读库。

  2. 调整热点缓存策略

    1. 使用热点缓存库

  3. 使用互斥锁-mutex

    1. 初阶玩家:到期上锁

    2. 高阶玩家:提前上锁,然后做异步缓存刷新,刷新完成后,将锁取消

 

https://img1.sycdn.imooc.com//63272d19000197ae06150281.jpg

解决方案:

  1. 调整缓存过期策略

    1. 初阶玩家:设置缓存永不过期

    2. 高阶玩家:读写分离架构-利用Canal做数据异构方案,做一个读写分离的架构,用缓存当做读库。

  2. 过期时间散列-过期时间由基础时间+动态散列时间(1-10分钟随机的时间),将过期时间分散开来,不会产生集中过期的现象。

  3. 缓存预热,在业务正式开始之前把缓存构建起来。

 

https://img1.sycdn.imooc.com//63272d1a00018b6305790247.jpg

黑客使用不存在P03商品请求数据,由于缓存不存在,将直接查询数据库,由于数据库也不存在, 所有的巨量的P03商品的请求都将请求到数据库,将数据库打崩

解决方案:

  1. 数据不存在时,也可以在缓存中构建key-value,key有值,value为空的缓存

  2. 布隆过滤器:hash散列技术判断当前查询请求是否存在后端数据库中的方案。

    1. 高阶玩家:进击版布隆过滤器。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消