广告位联系
返回顶部
分享到

resty更新header控制api版本数据源读写分离

相关技巧 来源:互联网 作者:秩名 发布时间:2022-03-08 09:19:38 人浏览
摘要

前言 Resty目前积累到450 star,还有1个多月满一年了,在没有推广的情况下如果能积累到500 star,真是棒棒的,如果觉得不错可以给颗心(https://github.com/Dreampie/Resty),希望大家多多鼓励,也

前言

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

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

1.使用header来控制api版本

最初设计的api控制方式主要基于url的版本控制,更新时要么提供一个基础的ApiResource,要么提供一个新的项目做为新版本接口,作为一个强迫症一直对此功能心怀不满。

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

1

2

3

4

5

@GET(value = "/:get", headers = {"Accept: application/vnd.resty.v1+json"})

//使用:来分割key和value

  public WebResult<List<User>> get(String get, Date x, HttpResponse response) {

    throw new WebException(HttpStatus.NO_CONTENT, "xxx");

  }

2.读写分离的数据源支持

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

1

2

3

4

5

6

//读写分离

    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://github.com/Dreampie/aspectj-demo


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。

您可能感兴趣的文章 :

原文链接 : https://www.oschina.net/news/68791/resty-1-2-0-snapshot
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计