跳到主要内容

如何保证查询节目时避免缓存穿透

建议小伙伴先要理解缓存穿透的概念,以及在用户服务中的注册用户业务时是怎样防止缓存穿透的,可跳转到下面的章节来学习

业务讲解-用户注册-如何巧妙应对缓存穿透

阅读过上面章节的小伙伴应该知道了 缓存穿透是指查询的数据在缓存和数据库中都不存在导致每次查询这条数据都会穿透过缓存,直接去查询数据库,相当于没有缓存一样。

而这种问题在查询节目详情时同样会存在,比如说某个黑客调用节目详情接口时,就会传入一个不存在的节目id,先查一遍缓存,缓存不存在则再去查询数据库,结果数据库也不存在,当并发高时,就会对数据库造成很大的压力

在注册用户功能中,我们结合了验证码和布隆过滤器的方案来解决缓存穿透,那么在查询节目详情功能中,应该用什么方案呢?我们从业务特点来入手:

正常用户查询节目详情时,都是事先查询了节目主页或者节目列表后,再来查询节目详情的,也就是说节目id时肯定存在缓存或者数据库中的,如果是缓存和数据库都不存在的节目id说明此id就是不正常的,服务收到了此id就应该直接拒绝,不再执行后续的流程

注意这里的关键点,如果判断节目id不存在,则说明此节目id肯定是不正常的

付费内容提示

该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放

加入星球后,你可以获得:

  • 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
  • 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
  • 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
  • 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠