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如何使用内存缓存

相关推荐
喜欢流萤吖~43 分钟前
微服务架构解析:从单体到分布式
spring boot·后端
小江的记录本1 小时前
【分布式】分布式核心组件——分布式锁:Redis/ZooKeeper/etcd 实现方案(附全方位对比表)、优缺点、Redlock、时钟回拨问题
java·网络·redis·分布式·后端·zookeeper·架构
好家伙VCC1 小时前
**发散创新:用Rust实现基于RAFT共识算法的轻量级分布式日志系统**在分布式系统中,**一致性协议**是保障数据可靠
java·分布式·python·rust·共识算法
晔子yy2 小时前
【JAVA探索之路】从头开始讲透、实现单例模式
java·开发语言·单例模式
chools7 小时前
【AI超级智能体】快速搞懂工具调用Tool Calling 和 MCP协议
java·人工智能·学习·ai
李白你好8 小时前
TongWeb EJB 反序列化生成工具(Java-Chain 插件)
java·安全
U盘失踪了9 小时前
Java 的 JAR 是什么?
java·jar
今天又在写代码9 小时前
java-v2
java·开发语言
competes10 小时前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql
2501_9130613410 小时前
网络原理知识
java·网络