API 管理这个话题近些年听到的频次越来越多,这本质上是个 web 领域的发展有关,也和开发协作方式有关--前后端分离代替了全栈工程师 hold all 的局面,强调的更多的是 API 复用、分工和协作细化。 API 管理的重要性不言而喻,每家公司随着业务的发展,多多少少都会涉及到;从开源社区的产品到国内各类商业化产品,可以看到大家对于 API 管理是越来越重视的。
结合自身的开发经历,我们先讨论下,为什么需要管理 API
从前一节的 case 来看,API 管理的过程是在逐步完善的,从以工程师视角管理到更规范化的基于管理工具的管理;“口口相传”会随着工程师的更替而逐渐失去管控,直到无法追溯;基于文档的管理,从实际情况来看,两次变更之后就会慢慢的弱化文档的地位(改一次接口,就得改一次文档),取而代之的还是工程师主导;还有一点是,不管是基于“口头协定”还是文档,接口在没有交付之前是不具备可测试性的,而且面向的主体单一,一旦使用端的数量多了,资源分散和协调的人力成本将指数级增长。
API 管理不仅仅是提高技术能力,而是帮助推动业务更上一层楼,好的 API 管理可以带给我们的收益是非常大的。
关于 API 管理这块,我们现在还有专门的 API 技术工作组来负责统筹所有服务的 API 相关事项,包括设计规范、自动化工具套件建设、API 管理建设等等。但是由于多语言栈、历史接口文档零散、开源工具停止维护等原因,导致相关工作推进起来非常麻烦。
这些问题也迫使我们在不断寻求各种解决方案,也包括各种商业 API 管理工具的调研,以便于能够给我带来新的解题思路;国内目前企业级的主要 Apifox、ShowDoc、Eolinker,国外有 boomi、apigee 等(国外的相较于国内的产品要贵不少);下面主要从功能上对比当前使用 Yapi 和 在调研 Apifox(公网 SaaS 版免费)。
下面主要是从功能上来看,从持续维护方面来说,Yapi 是社区驱动,没有多少利益牵扯,从 github 上看已经有很久没有新的提交了,issue 也缺乏跟进(情怀很重要,但是吃饭更重要,维护一个产品真的很难,是需要给 Yapi 开发小伙伴点赞的);Apifox 是商业产品,在持续维护和技术支持上不用怎么担心。
结论:总体来说 SaaS 版本的 Apifox 相比于 Yapi 来说,功能面板更加丰富些;包括了项目统计,在线分享,代码生成等。操作上来说,Yapi 需要从分类 -> 项目 -> 接口,个人感觉内部的功能 tab 没有 apifox 的合理。
结论:接口信息整体差异不大,功能上多了云端 Mock 和快速请求,Apifox 直观感受更加丰富和聚焦。
结论:区别不大,但是 Apifox 有独立的数据模型管理(可复用的数据结构,定义接口返回数据结构及请求参数数据结构(仅 JSON 和 XML 模式)时可直接引用。支持模型直接嵌套引用,直接 JSON/XML 智能导入,支持 oneOf、allOf 等高级组合模式),Yapi 没有。
结论:apifox 在支持的导入源上更丰富,可以满足企业的不同诉求。(Yapi 好像不支持 Swagger 1)
提供接口集合测试,可以通过选择接口(或接口用例)快速创建测试集。这一点在前文的介绍中有说过,这个是我们当前的痛点之一,就是组合接口的自动化测试。
我们当前对外部合作的三方是不友好的,由于业务迭代速度和一些定制化的需求,开放平台能提供的接口 API非常有限。大多数情况下,我们都是通过文档将接口的调用逻辑、参数及返回结果语义发送给外部用户(出于安全管控,外部没法直接访问我们的 API 平台,API 接口截图也会留痕)。 Apifox 项目可“在线分享” API 文档,分享出去的 API 文档可设置为公开或需要密码访问,非常方便与外部团队协作,完成协作之后也不用担心合作方会把接口扩散出去(变更密码或者关闭授权)。
可以感受下:https://www.apifox.cn/apidoc/s/ce387612-cfdb-478a-b604-b96d1dbc511b/http/5041285
1-3 所提供的能力确实是戳中了我们的痛点,这可能也是绝大多数公司所共有的问题,Apifox 这几点在产品上的设计个人觉得还是非常优秀的。
本文主要结合自身的一些经历以及当前工作中所遇到的问题,对正在使用的开源产品 Yapi 和在调研的 Apifox 做了一些对比和介绍;整体来看 Apifox SaaS (免费版) 相较于 Yapi 来说,还是有不少优势的。apifox.cn。
如果是个人开发者,小团队,或者研发预算有限的公司来说(没有任何功能限制,没有团队使用人数限制,也没有项目和接口数量限制),白嫖即可;对于常规保密级别的项目, SaaS 版本其实已经够用了。如果对于安全和保密要求较高, 可以考虑私有化部署。关于 Apifox 更多可以见其官网 www.apifox.cn。
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。