- DBApi的插件分两类,一类是数据转换插件,一类是缓存插件
- 有时候sql无法一次性获得自己想要的数据格式,如果用代码对数据进行一些处理转换能更加方便,这时候就要用到数据转换插件。用户自己编写数据转换逻辑的代码。
- 比如针对sql查询结果中的用户手机号、银行卡号进行转换脱敏。
- 如果一个API内包含多条sql,那么每条sql会对应一个数据转换插件配置,数据转换插件永远是针对单条sql查询结果进行转换
- 主要是对查询类API,sql查询结果进行缓存,这样避免频繁的查询数据库,对数据库造成压力。
- 缓存逻辑由用户自己编写,用户可以缓存到redis/mangodb/elasticsearch等等。
- 当从缓存中查询不到数据时,才去数据库查询,同时将结果缓存下来。
- 如果一个API内包含多条sql,那么缓存插件是对多条sql执行的结果(如果单条sql配置了转换插件,会先转换结果)封装成一个整体后,对整体进行缓存
- 插件使用java语言编写,准备java(8+)开发环境
- 新建maven项目,pom里引入
dbapi-plugin
<dependency>
<groupId>com.gitee.freakchicken.dbapi</groupId>
<artifactId>dbapi-plugin</artifactId>
<version>3.0.0</version>
<scope>provided</scope>
</dependency>
- 新建java类实现
com.gitee.freakchicken.dbapi.plugin.CachePlugin
import com.gitee.freakchicken.dbapi.common.ApiConfig;
import com.gitee.freakchicken.dbapi.plugin.CachePlugin;
import java.util.Map;
public class Cdemo extends CachePlugin {
/**
* 插件初始化方法,实例化插件的时候执行,永远只会执行一次,
* 一般是用来创建连接池
*/
@Override
public void init() {
}
/**
* 缓存设置
*
* @param config api配置
* @param requestParams request参数
* @param data 要缓存的数据
*/
@Override
public void set(ApiConfig config, Map<String, Object> requestParams, Object data) {
}
/**
* 清除所有缓存,API修改、删除、下线的时候会触发清除缓存
*
* @param config api配置
*/
@Override
public void clean(ApiConfig config) {
}
/**
* 查询缓存
*
* @param config api配置
* @param requestParams request参数
* @return
*/
@Override
public Object get(ApiConfig config, Map<String, Object> requestParams) {
return null;
}
}
init
方法是插件初始化方法,只会执行一次,一般用来初始化连接池,比如初始化redis连接池get
方法是获取缓存中的数据的方法,第一个参数是api配置,第二个参数是请求的参数set
方法是设置缓存的方法,当执行sql查询结果后,会调用set方法。第一个参数是api配置, 第二个参数是请求的参数,第三个参数是sql查询结果,如果api配置了数据转换插件的话,就是转换后的结果clean
是清空缓存的方法,当API的修改、下线、删除的时候,会执行这个clean
方法
- 新建java类,实现
com.gitee.freakchicken.dbapi.plugin.TransformPlugin
import com.alibaba.fastjson.JSONObject;
import com.gitee.freakchicken.dbapi.common.ApiConfig;
import com.gitee.freakchicken.dbapi.plugin.TransformPlugin;
import java.util.List;
public class Tdemo extends TransformPlugin {
/**
* 插件初始化方法,实例化插件的时候执行,永远只会执行一次,
*/
public abstract void init(){}
/**
* 数据转换逻辑
* @param data sql查询结果
* @param params 缓存插件局部参数
* @return
*/
public abstract Object transform(List<JSONObject> data, String params){
return null;
}
}
- 数据转换逻辑写在
transform
方法里,第一个参数就是sql查询结果,第二个参数是插件局部参数
- 如果想在插件内打印日志,推荐直接调用父类的
logger
super.logger.debug("set data to cache");
- 设计插件全局参数的目的,是为了方便一个插件在不同的环境中使用
- 插件全局参数是每个插件自身的参数,与API无关,比如缓存插件需要连接的redis的ip、端口信息。配置在文件
conf/plugin.properties
中。 - 全局参数主要是为了方便不同环境的切换,比如测试环境和生产环境需要连接不同的redis地址,那么把redis地址信息配在配置文件就很方便。
- 如果用户想添加插件的全局配置,可以直接在
plugin.properties
文件中添加配置,比如:
RedisCachePlugin.ip=127.0.0.1
RedisCachePlugin.port=6379
RedisCachePlugin.db=0
RedisCachePlugin.password=
- 代码获取插件全局参数值的方法:
import com.gitee.freakchicken.dbapi.plugin.PluginConf;
String ip = PluginConf.getKey("RedisCachePlugin.ip")
-
设计插件局部参数的目的,是为了让一个插件能够被多个API灵活的复用
-
插件局部参数是为每个API单独指定的参数,参数值从页面上配置进去(创建、编辑API的时候)。
-
比如针对redis缓存插件,不同的API需要设置不同的缓存时间, 那么每个API调用同一个缓存插件的时候,就可以传递不同的时间参数进去。 又比如针对字段加密插件,每个API需要加密的字段都不一样,那么每个API调用同一个字段加密插件的时候,就可以传递不同的字段名参数进去。 这样可以让一个插件灵活的被多个API复用。
-
代码获取插件局部参数值的方法:
import com.gitee.freakchicken.dbapi.common.ApiConfig;
// 缓存插件获取局部参数,从ApiConfig获取
String params = ApiConfig.getCachePluginParams();
// 数据转换插件获取局部参数,直接就是transform方法的params参数
public abstract Object transform(List<JSONObject> data, String params){
- 用户开发完插件后,请打包,将最后生成的jar包和插件依赖的jar包拷贝进DBApi的
lib
目录下, 再重启DBApi服务(如果是集群模式,每个节点都需要拷贝jar包并重启集群),就可以使用插件了 - 如果插件中使用了全局参数,还需要在
conf/plugin.properties
文件添加相应配置并重启生效(如果是集群模式,每个节点都需要添加相应配置并重启生效)