首页 > 作文

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

更新时间:2023-04-06 01:53:23 阅读: 评论:0

前言

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

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

1.使用header来控制api版本

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

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

@get(value="/:get",headers={"accept:application/vnd.resty.v1+json"})//使用:来分割key和valuepublicwebresult<list<ur>>get(stringget,datex,httpresponrespon赤诚善良){thrownewwebexception(httpstatus.no_content,"xxx");}

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

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

//读写分离druiddatasourceproviderwritedsp=newdruiddatasourceprovider("write");druiddatasourceproviderreaddsp=newdruiddatasourceprovider("read");activerecordpluginactiverecordddsp=newactiverecordplugin("readwrite",writedsp,readdsp);activerecordddsp.addincludepackages("cn.dreampie.resource六年级上册数学课本");pluginloader.add(activerecordddsp);

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

相关链接:

resty 的详细介绍:

resty 的下载地址:

以上就是resty更新header控制api版本数据源读菜婆婆写分离的详细内容,更多关于header控制api数据源读写分离的资料请关注www.887551.com其它相关文章!

本文发布于:2023-04-06 01:53:20,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/056eb38a1be6444552f47049ac5fbd93.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:resty更新header控制api版本数据源读写分离.doc

本文 PDF 下载地址:resty更新header控制api版本数据源读写分离.pdf

下一篇:返回列表
标签:版本   数据源   提供一个   接口
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图