博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Resty 1.2.0-SNAPSHOT 更新,可通过header来控制api的版本,数据源读写分离
阅读量:6350 次
发布时间:2019-06-22

本文共 1347 字,大约阅读时间需要 4 分钟。

Resty目前积累到450 star,还有1个多月满一年了,在没有推广的情况下如果能积累到500 star,真是棒棒的,如果觉得不错可以给颗心(,希望大家多多鼓励,也希望有心的同学参与维护,开源说明它属于大家,无论你使用或者作为一个框架的基础学习还是从中得到灵感做出好用的东西 都希望你能和大家一起分享 开源希望大家互相帮助

本次更新说大不大说小不小,主要解决一下对api的控制问题:

1.使用header来控制api版本

最初设计的api控制方式主要基于url的版本控制,更新时要么提供一个基础的ApiResource,要么提供一个新的项目做为新版本接口,作为一个强迫症一直对此功能心怀不满,我一直以来对团队要求都是只要更新没有影响到整体返回的数据结构,是不允许升级接口的版本号的,兼容老版本非常重要,如果遇到重构和结构大规模变化,通过header来提供一个新的api并保留老api一段时间(我们为客户端提供了强制升级计划,一旦启动客户端必须升级到新版本),后续会把老的api清理掉,理论上一个api最多存在两个版本,如果不是只能说明你设计的接口稳定性较弱,自由可控对强迫症来说非常重要,示例:

@GET(value = "/:get", headers = {"Accept: application/vnd.resty.v1+json"})//使用:来分割key和value  public WebResult
> get(String get, Date x, HttpResponse response) { throw new WebException(HttpStatus.NO_CONTENT, "xxx"); }

2.读写分离的数据源支持,简单配置不需要考虑太多,同时提醒:如果本次请求的事务范围内即有读由有写,会根据你的@Transaction注解的事务来使用连接,比如需要写入库的连接,那么读取时也会使用写入库的连接,节省一次打开读取库连接的资源

//读写分离    DruidDataSourceProvider writeDsp = new DruidDataSourceProvider("write");    DruidDataSourceProvider readDsp = new DruidDataSourceProvider("read");    ActiveRecordPlugin activeRecordDdsp = new ActiveRecordPlugin("readwrite", writeDsp, readDsp);    activeRecordDdsp.addIncludePackages("cn.dreampie.resource");    pluginLoader.add(activeRecordDdsp);

另外一直对使用java代码的动态代理实现的aop感觉不好,如果有人能提供基于aspectj的嵌入代码来实现事务来提高代码的优化,那就非常感谢了,目前有个aspectj简单的例子:

文章转载自 开源中国社区[https://www.oschina.net]

你可能感兴趣的文章
阿里云前端周刊 - 第 28 期
查看>>
iOS 主队列同步造成死锁的原因
查看>>
es6 下比较对象是否有修改的简要方法
查看>>
windows安装mysql
查看>>
你还在看《深入理解Java虚拟机》的运行时数据模型吗?
查看>>
RIS,创建 React 应用的新选择
查看>>
线性结构上的动态规划--算法竞赛入门经典笔记
查看>>
面试官:你使用webpack时手写过loader,分离过模块吗?
查看>>
Ubuntu 16.04系统下 对OpenJDK编译好的Hotspot 进行调试
查看>>
00-利用思维导图梳理JavaSE基础知识-持续更新中!
查看>>
java中三种注释及其实际应用的意义
查看>>
Emacs 24.2 for Mac OS X 最新版的 MAC Emacs 安装包
查看>>
【三石jQuery视频教程】01.图片循环展示
查看>>
ngrok
查看>>
ThinkPHP 模板变量输出
查看>>
android系统信息(内存、cpu、sd卡、电量、版本)获取
查看>>
HTML5、WebKit与移动应用开发
查看>>
面google的试题,对google面试题的衍生推导
查看>>
Eclipse Debug Android Native Application
查看>>
java动态代理
查看>>