如何保证查询节目时避免缓存穿透
建议小伙伴先要理解缓存穿透的概念,以及在用户服务中的注册用户业务时是怎样防止缓存穿透的,可跳转到下面的章节来学习
阅读过上面章节的小伙伴应该知道了 缓存穿透是指查询的数据在缓存和数据库中都不存在,导致每次查询这条数据都会穿透过缓存,直接去查询数据库,相当于没有缓存一样。
而这种问题在查询节目详情时同样会存在,比如说某个黑客调用节目详情接口时,就会传入一个不存在的节目id,先查一遍缓存,缓存不存在则再去查询数据库,结果数据库也不存在,当并发高时,就会对数据库造成很大的压力
在注册用户功能中,我们结合了验证码和布隆过滤器的方案来解决缓存穿透,那么在查询节目详情功能中,应该用什么方案呢?我们从业务特点来入手:
正常用户查询节目详情时,都是事先查询了节目主页或者节目列表后,再来查询节目详情的,也就是说节目id时肯定存在缓存或者数据库中的,如果是缓存和数据库都不存在的节目id说明此id就是不正常的,服务收到了此id就应该直接拒绝,不再执行后续的流程
注意这里的关键点,如果判断节目id不存在,则说明此节目id肯定是不正常的
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
- 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
