《优化接口设计的思路》系列:第1篇—什么是接口缓存

一、缓存的定义:

缓存是一种存储数据的技术,用于提高数据访问的速度和效率。缓存通常存储在内存中,因为内存访问速度远快于磁盘和网络。数据接口通常会使用缓存技术,以降低对后端数据存储和处理的压力,提高系统性能。

当我们访问一个页面以后,这个页面中的静态资源(如图片、HTML文件、JavaScript文件等)往往会被浏览器保存下来,这个过程称为缓存(cache)。这么做是为了使用户再次访问相同页面的时候,这些静态资源不用从服务器重新下载到本地,而从缓存中直接读取,这样就加快了页面访问的速度,同时减轻了服务器和网络带宽的压力。

二、接口缓存:

1、什么是接口的后台缓存

前台访问后台接口,后台会优先从缓存(内存)中查找接口数据;

如果有数据,直接对前台响应缓存数据;

如果没有数据,与(mysql)数据库交互,得到数据,对前台响应,同时将数据进行缓存,以备下次使用;

2、前台缓存

前台在请求到接口数据后,在前台建立缓存,再发送同样请求时,发现前台缓存有数据,就不再对后台做请求了

3、什么的接口会进行接口缓存

i)接口会被大量访问:比如主页中的接口,几乎所有人都会访问,而且会重复访问

ii)在一定时间内数据不会变化(或数据不变化)的接口

iii)接口数据的时效性不是特别强(数据库数据发生变化了,不是立即同步给前台,验后时间同步给前台也没事)

注:理论上所有接口都可以建立缓存,只要数据库与缓存数据同步及时

三、举个例子:

现有一个使用商品名称查询商品的需求,要求先查询缓存,查不到则去数据库查询;从数据库查询到之后加入缓存,再查询时继续先查询缓存。

相关推荐
wuyunhang1234562 小时前
Redis---集群模式
数据库·redis·缓存
没有bug.的程序员4 小时前
Redis 大 Key 与热 Key:生产环境的风险与解决方案
java·数据库·redis·缓存·热key·大key
wuyunhang1234564 小时前
Redis----缓存策略和注意事项
redis·缓存·mybatis
零雲4 小时前
除了缓存,我们还可以用redis做什么?
数据库·redis·缓存
梦中的天之酒壶4 小时前
多级缓存架构
缓存·架构
We....4 小时前
Java 分布式缓存实现:结合 RMI 与本地文件缓存
java·分布式·缓存
森林-7 小时前
MyBatis 从入门到精通(第三篇)—— 动态 SQL、关联查询与查询缓存
sql·缓存·mybatis
虫小宝7 小时前
返利软件的分布式缓存架构:Redis集群在高并发场景下的优化策略
分布式·缓存·架构
lifallen7 小时前
字节跳动Redis变种Abase:无主多写架构如何解决高可用难题
数据结构·redis·分布式·算法·缓存
C++_girl9 小时前
缓存未命中
c++·缓存