缓存穿透/击穿/雪崩的解决方案

  1. 缓存穿透

  是什么

    缓存中没有某条数据,导致大量的请求落到关系型数据库

  怎么办

    1. 缓存中没有从关系型数据库中查,null值也要保存在缓存中,设置较短的过期时间,有值的时候更新缓存  
    2. 使用布隆过滤器 提前过滤大量不存在的key 
  1. 缓存击穿

  是什么

    缓存中某条数据过期失效,高并发落到关系型数据库

  怎么办

    1. 热点数据永不过期
    2. 分布式锁互斥锁,由一条请求去请求数据库并更新缓存
    3. 重要接口一定要实现限流,服务熔断 快速返回      
  1. 缓存雪崩    

  是什么

    大量数据同时失效 导致请求落到关系型数据库      

  怎么办

    1. 设置随机的过期时间
    2. 热点数据永不过期      

 

posted @   rudynan  阅读(107)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示