资讯专栏INFORMATION COLUMN

干货 | Api 体系架构分享(下)

leon / 2230人阅读

摘要:上一篇,讲到了,最近,在做的设计对于设计,一方面是对于后端框架的设计,另一方面呢,是对于整个体系的设计在这里呢,我们来理理思路,先来大致分一下块风格就不用说了,我们就用风格,接下来,也就是我们所说的接口描述语言框架,整个服务的核心驱动版本控

上一篇,讲到了,最近,在做 api 的设计

对于设计,一方面是对于后端 server 框架的设计,另一方面呢,是对于整个 api 体系的设计

在这里呢,我们来理理思路,先来大致分一下块

风格就不用说了,我们就用 restful 风格,接下来:

IDL,也就是我们所说的接口描述语言

server 框架,整个 api 服务的核心驱动

版本控制

还有一些辅助工具,比如说,自动化工具、认证授权、监控上报、日志记录、检索等等


上次呢,讲了 IDLserver 框架的设计思路

这次呢,来吧剩下两个也给说说

版本控制

说到版本控制,大多数人的大脑中都一定会立刻想到 gitsvn 吧,只可惜,这次的主角可不是他们

虽说 git 和 svn 虽好,对于一些项目也能够进行很好的开发,但是呢,对于某些场景,还是有些 hold 不住的

比如,我们来举一个场景:

现在我们的源码大约有 500M,然后呢,采用的是分支开发,主干发布,但是呢,因为我们是提供中间层 service 的,迭代周期很短,对于一些特殊的客户,会时常有些特殊的逻辑处理,每个开发者可能会有好几个分支进行开发,这个样子的话,对于这些特殊逻辑,特殊版本的管理就非常的不方便,而且,因为每次都要拉出来一个分支,然后改动可能非常小,这就造成了非常大量的冗余量

于是,这个场景中,冗余量、大量迭代版本的管理,就上升到了我们的一个主要问题

如何解决呢?

单体代码库

在这里,我们引入一个节点(标签)的概念,先来说一下整体思路

现在,我们就抛弃 gitsvn 的思想,把所有的代码都放在一起,通过控制 节点粒度 来控制整体的冗余

首先,节点粒度我们先设定为以文件为单位,同时呢,约定我们的命名规范,文件名.节点标识.php,例如 Test.v1.php

接下来呢,就会有我们原始的版本,在这个原始的版本里面,所有的文件都是 base 节点

所有的文件都会有一个父节点,最终都是继承与 base 节点的

当我们需要迭代到 1.0.1 版本的时候,我们只要把需要改动的文件 copy 一个副本,然后按规范命名,接着只需对于这一个文件进行改动,这样,冗余的粒度就控制在了这个文件内

大大减少冗余的同时,还大大的提高了代码的复用,避免了菱形依赖,不同团队间的跨团队协作也变得更加灵活

接下来,我们怎么能够正常调用呢?

所以说,这种单体代码库需要一个路由引擎来驱动,这就要我们根据实际情况来实现了,可以直接根据节点表示来路由,也可以在中间加一层路由映射表,这就看具体需求了

同理,我们可以进一步调整节点粒度,来控制整体的冗余,比如,粒度细化到接口级别

~~~~~~ 萌萌哒的分割线 ~~~~~~~~~

好了,下面就来分析一下这种单体代码库的优劣

优点:

统一版本控制

广泛地代码共享和复用

简化依赖管理,避免菱形依赖

原子修改

大规模重构

跨团队协作

灵活的团队边界和代码所有权

代码可见性以及清晰的树形结构提供了隐含的团队命名空间

但是呢,随着代码量的增加,也会出现以下问题

单体模型让代码结构更容易理解,但却让代码发现变得更困难

开发人员需要能够查看代码库,找到相关程序库,并看看如何使用它们以及谁编写了它们。这就需要有代码搜索和代码浏览工具

依赖重构和代码清理辅助工具,定期对无用代码进行清理

版本管理的重心转移到了冗余控制上

所以说呢,对于管理,我们就需要开发一套额外的自动化工具了

具体关于单体代码库的细节也可以查看这篇文章:


ok,关于版本控制就说这么多,接下来就是最后的一些自动化工具以及辅助工程了

自动化工具

为什么需要自动化工具呢?

一方面,节约我们维护开发的成本,对于一些可以自动化的操作就没必要去人工操作

另一方面呢,也是为了减少人工操作中可能带来的一些失误

就比如我们现在的 api,都需要哪些自动化工具呢?

SDK 自动生成工具:对于我们提供给用户的 SDK,我们当然不希望每次迭代都要重新给用户写一份新的,所以说呢,通过自动化工具,自动生成各种语言调用的 SDK 是很有必要的

IDL 解析工具:我们在读取数据的时候,肯定不能每次都去解析 IDL 的结构,这样会带来太多不必要的额外开销,所以说呢,我们需要提前解析 IDL 进行缓存,从而提高我们调用的速度,而这个解析生成的过程,就交给工具来完成了

代码库搜索工具:因为我们采用了单体代码库,所以慢慢的代码越来越多,代码搜索工具就变的必不可少了

代码发现工具:也是为了维护代码库,定期发现清理无用代码

至于一些其他的自动化工具,就根据大家的具体需求去实现吧,也就不一一列举了

其他辅助工具

比如说,认证、授权、监控、上报、日志等等

这些在 server 框架设计的同时就都要考虑进去,什么时候需要上报,如何设定日志格式从而使得我们能够更加方便的去维护等等

对于日志管理,可以使用一些开源系统快速搭建

比如,logstash 来搭建日志管理系统,通过 ElasticSearch 来进行索引检索服务,然后呢使用 kibana 作为分析和可视化平台


ok,api 设计分享就到这里

FROM: 一只热爱动漫的攻城狮 ~ ~ ~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/9609.html

相关文章

  • 干货 | Api 体系架构分享

    摘要:上一篇,讲到了,最近,在做的设计对于设计,一方面是对于后端框架的设计,另一方面呢,是对于整个体系的设计在这里呢,我们来理理思路,先来大致分一下块风格就不用说了,我们就用风格,接下来,也就是我们所说的接口描述语言框架,整个服务的核心驱动版本控 上一篇,讲到了,最近,在做 api 的设计 对于设计,一方面是对于后端 server 框架的设计,另一方面呢,是对于整个 api 体系的设计 在这...

    asce1885 评论0 收藏0
  • 干货 | Api 体系架构分享(上)

    摘要:最近呢,在做的设计对于设计,一方面是对于后端框架的设计,另一方面呢,是对于整个体系的设计在这里呢,我们来理理思路,先来大致分一下块风格就不用说了,我们就用风格,接下来,也就是我们所说的接口描述语言框架,整个服务的核心驱动版本控制还有一些辅助 最近呢,在做 api 的设计 对于设计,一方面是对于后端 server 框架的设计,另一方面呢,是对于整个 api 体系的设计 在这里呢,我们来理...

    impig33 评论0 收藏0
  • 我是如何学习小程序的

    摘要:行胜于言,理论结合实践才是王道,所以本文我将基于前面的学习方法,分享我是如何学习微信小程序的。第二个目标则需要学习小程序的插件相关接口调用,以及蝉知建站系统这边的微信模块代码。 前段时间和大家一起分享了一篇关于学习方法内容《大牛与搬运工的差距——学习方法的力量》。我们将学习过程分成八步,并借鉴了敏捷开发的迭代思想,以达到自我迭代学习的效果。行胜于言,理论结合实践才是王道,所以本文我将基...

    XGBCCC 评论0 收藏0
  • 进阶Java架构师必看的15本书

    摘要:阿里巴巴的共享服务理念以及企业级互联网架构建设的思路,给这些企业带来了不少新的思路,这也是我最终决定写这本书的最主要原因。尽在双阿里巴巴技术演进与超越是迄今唯一由阿里巴巴集团官方出品全面阐述双八年以来在技术和商业上演进和创新历程的书籍。 showImg(https://segmentfault.com/img/remote/1460000015386860); 1、大型网站技术架构:核...

    Julylovin 评论0 收藏0
  • 架构师必收藏的干货!!!

    摘要:一微服务概念微服务体系结构由轻量级松散耦合的服务集合组成。每个服务都有自己的计划测试发布部署扩展集成和独立维护。团队不必因为过去的技术决定而受到惩罚。用在这里是指将相关的服务通过聚合器聚合在一起,这个聚合器就是门面。 微服务架构现在是谈到企业应用架构时必聊的话题,微服务之所以火热也是因为相对之前的应用开发方式有很多优点,如更灵活、更能适应现在需求快速变更的大环境。 一、微服务概念 微服...

    shiweifu 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<