DBAPI如何使用内存缓存

背景

  • 在使用DBAPI创建API的时候,有时候SQL查询比较耗时,如果业务上对数据时效性要求不高,这种耗时的SQL可以使用缓存插件来将数据缓存起来,避免重复查询。

  • 一般来说,可以使用redis memcache等缓存服务来存储缓存数据。但是这就需要公司有团队去运维支撑缓存服务,这就增加了公司的运营成本。

  • DBAPI在设计上一直秉持着轻量化的设计原则,所以官方也提供了内存缓存插件,它直接使用DBAPI服务自身的内存来缓存数据,不需要额外的缓存服务。

使用方法

  • 将下载的压缩包解压,解压后的文件全部复制到DBAPI的lib目录下,重启DBAPI

  • 创建或者编辑API的时候,在全局插件标签下选择内存缓存插件即可。页面上不用填写插件参数,缓存会自动生效。

插件参数设置

缓存时间

  • 缓存时间默认是缓存1分钟

  • 如果要修改缓存时间,只能修改全局插件参数,在conf目录下的plugin.properties文件中添加如下配置(单位是分钟):

    memory.cache.expireAfterWrite=1

缓存空间大小

  • 因为缓存占用了DBAPI自身的内存空间,所以插件限制了缓存元素的最大数量,默认是1000

  • 如果要修改缓存空间大小,只能修改全局插件参数,在conf目录下的plugin.properties文件中添加如下配置:

    memory.cache.size=1000

插件文档

  • 更多详细请阅读内存缓存插件文档

  • 如果您想了解更多插件相关的,或者自己开发插件,请阅读DBAPI如何使用内存缓存

相关推荐
JosieBook11 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
一生了无挂12 小时前
Java处理JSON技巧教学(从基础到高阶实战全覆盖)
java·开发语言·json
李白的天不白12 小时前
使用 SmartAdmin 进行前后端开发
java·前端
swordbob13 小时前
Spring 单例 Bean 是线程安全的吗?
java·开发语言
2601_9516437713 小时前
Python第一,Java跌出前三,C语言杀回来了
java·c语言·python·编程语言排行·技术趋势
IT 行者15 小时前
GitHub Spec Kit 实战(五):/speckit.tasks 怎么拆——Spec Kit 五部曲收官
java·ai编程·claude
(Charon)15 小时前
【C++ 面试高频基础:指针、引用、const、static、new/delete 总结】
java·开发语言
Yeats_Liao16 小时前
Feed流系统设计(三):数据模型与存储设计,从表结构到Redis收件箱
java·javascript·redis
JiaHao汤16 小时前
分布式事务方案全景:从理论到 Seata 落地
java·分布式·spring·spring cloud
色空大师17 小时前
【debug调试详解-idea】
java·ide·intellij-idea·调试·远程调试