网关实现的缓存基本都是用临时缓存 + TTL 方式实现的。当用户请求服务端时,被缓存的 API 如果之前已经被请求过,并且缓存还没有过期的话,就会直接返回缓存内容给客户端。这个方式能大大降低后端的数据服务压力。 不过每一种技术选择,都是反复权衡的结果,这个方式是牺牲了数据的强一致性才实现的。另外,这个方式对缓存能力的性能要求比较高,必须保证网关缓存可以扛得住外网流量的 QPS。 如果想预防穿透流量过多,也可以通过脚本定期刷新缓存数据,网关查到相关缓存就直接返回,如果没有命中,才会将真正请求到服务器后端服务上并缓存结果。这样实现的方式更加灵活,数据的一致性会更好,只是实现起来需要人力去写好维护代码。
相关推荐
Asthenia04123 小时前
浏览器缓存机制深度解析:电商场景下的性能优化实践databook4 小时前
『Python底层原理』--Python对象系统探秘超爱吃士力架5 小时前
MySQL 中的回表是什么?追逐时光者6 小时前
Plotly.NET 一个为 .NET 打造的强大开源交互式图表库苏三说技术6 小时前
10亿数据,如何迁移?bobz9656 小时前
openvpn 显示已经建立,但是 ping 不通customer087 小时前
【开源免费】基于SpringBoot+Vue.JS个人博客系统(JAVA毕业设计)qq_459238497 小时前
SpringBoot整合Redis和Redision锁灰色人生qwer7 小时前
SpringBoot 项目配置日志输出阿华的代码王国8 小时前
【从0做项目】Java搜索引擎(6)& 正则表达式鲨疯了&优化正文解析