当前位置: 首页 > article >正文

系统设计 总结

缓存雪崩、击穿、穿透

雪崩:大量缓存数据同时过期,或缓存服务器故障,会有大量请求同时打到数据库。解决 大量数据同时过期:

  • 过期时间加随机数,保证数据不会在同一时间过期。
  • 业务线程发现缓存数据失效时,通过mq发送消息给后台进程异步更新缓存
  • 发现redis中没有数据时,通过互斥锁或分布式锁,保证同一时间只有一个线程更新缓存。?
    解决 redis故障:
  • 增加服务熔断限流机制,防止把redis打崩
  • redis高可用集群。哨兵模式,主节点故障时自动选主。

击穿:属于雪崩的一种,热点数据过期或者系统资源限制被淘汰掉(lru)。

  • 不给热点设置过期时间,后台进程定期更新缓存
  • 业务线程在热点数据过期前,mq通知后台进程更新缓存

缓存穿透:数据既不在缓存,也不在数据库中。一般由于业务误操作删除了缓存和数据库中数据,或者非法数据,比如恶意攻击。
解决:

  • 请求入口过滤非法数据,比如反作弊算法,ip为0,0,0,0请求的过滤
  • 加入无结果cache(防御性),在链路上游
  • 布隆过滤器快速过滤,在写入数据库时使用布隆过滤器做个标记。布隆过滤器不存在一定不存在,判断存在则可能存在,因为存在哈希冲突,时间复杂度O(k),k是哈希函数个数。

http://www.kler.cn/a/416287.html

相关文章:

  • Stable Diffusion ControlNet基础
  • SpringBoot宠物领养服务:技术与创新
  • Facebook的开源项目解析:推动开发者社区的技术进步
  • 20241129解决在Ubuntu20.04下编译中科创达的CM6125的Android10出现找不到库文件
  • Vue 3 + Vuex 埋点实现指南
  • 【Stable Diffusion】安装教程
  • Unity UGUI 垂直循环复用滚动
  • GPU 服务器厂家:怎样铸就卓越 AI 算力?
  • DETR:一种新颖的端到端目标检测与分割框架
  • mac访达打开终端
  • github webhooks 实现网站自动更新
  • AI加持,华为全屋智能品牌升级为“鸿蒙智家”
  • 探索Java 17的新特性
  • 算法——赎金信(leetcode383)
  • android user版本默认usb模式为充电模式
  • C++趣味编程:基于树莓派Pico的模拟沙漏-倾斜开关与LED的互动实现
  • 深入理解 AI 产品的核心价值——《AI产品经理手册》
  • golang通用后台管理系统11(代码生成工具01)
  • 40分钟学 Go 语言高并发:【实战课程】工作池(Worker Pool)实现
  • hhdb数据库介绍(10-13)