对API进行版本控制的重要性和实现方式

作者 : 开心源码 本文共2324个字,预计阅读时间需要6分钟 发布时间: 2022-05-13 共152人阅读

我在API设计中收到的最常见问题之一就是如何对API进行版本控制。尽管并非所有API都完全相同,但我发现在API版本控制方面,某些模式和实践适用于大多数团队。我已经将这些内容收集起来,下面将提供少量关于版本控制策略的建议,该策略将帮助大多数API提供商,无论他们是向内部署API,还是对外的API。

API版本真的那么重要吗?

API是你与API使用者之间建立的纽带。正常情况下,你们之间的纽带不会轻易的断开。纽带包括URI模式,有效负载结构,字段和参数名称,预期行为以及其余内容。这种方法的最大好处是显而易见的:API使用者的了解不会变更,应用程序可以保证持续有效。

但是,永久不变是不现实的。有时由于业务变化,你可能需要对API进行重大改变。发生这种情况时,最好的方式是,你确保不会做任何会导致API使用者修复代码的事情。

打破与不间断的变化

非破坏性变更往往就像是“增加剂”,一般是增加新字段或者嵌套资源到资源陈述,又或者是添加新的端点,如PUT或者PATCH。API使用者从一开始应该构建能够适应这些非破坏性更改的用户端代码。

突破性变化包括:

1.名字段或者资源路径,通常在API发布后为了统一命名规范。

2.更改有效负载结构,一般是适应以下内容:

a.重命名或者删除字段

b.将字段从单个值更改为一对多关系(比方从一个帐户的一个电子邮件地址移动到这个帐户的电子邮件地址列表)。

c.修改了API的URL,导致返回结果不一致的情况。

简而言之,一旦你将API对外公开发布,你就必需保持它是可用的并且不会影响到使用者的。假如您遇到多个项目,则需要对API进行版本控制,以防止破坏现有的API使用者。

定义API版本策略

任何不断发展变化的API都需要API版本控制策略。你的API版本可以适应根据API使用者的期望而切换不同版本变得有所不同。我通常建议将以下API版本控制策略作为整体API管理系统的一部分。

1.假如你的API处于早期测试版本中,为了取得消费者的反馈,请建立您的API可能会发生变化的正确期望。在此阶段内,你会保留这个版本一段时间,由于你的API设计可能还会更改。作为消费者,API是不稳固的,因而他们应该预期到可能会发生的变化。

2.一旦发布,你的API应被视为契约,假如没有新版本,则不能被替换。

3.不间断的更改会导致次要版本出现问题,用户端会自动迁移到最新版本,不会出现任何负面反作用。

4.突破性的变化意味着用户必需迁移到此新版本,由于它包含一个或者多个重大更改。你必需与API使用者建立适当的时间表并定期沟通,以确保他们能方便地迁移到新版本。但在某些情况下,这可能无法马上实现,所以你的团队将会被要求暂时性支持以前的API版本。

何时必需实现API版本控制

一旦确定需要新版本的API,就需要知道如何解决它。实现API版本控制有三种常用方法。

1.资源版本控制

该版本是HTTP请求中Accept标头的一部分,例如,Accept:application/vnd.github.v3+json 发送到GET /customers。这考虑了许多版本控制的首选形式,由于资源在版本化的同时需要保持URI相同。假如未在Accept标头中提供,某些API会选择提供最新版本作为默认版本。

2.URI版本控制

该版本是URI的一部分,作为前缀或者后缀,例如,/v1/customers 或者/customers/v1。尽管URI版本控制不如基于内容的版本控制那么准确,但它往往是最常见的,由于它适用于不支持自己设置标头的各种工具。缺点是资源URI随每个新版本而变化,有些人认为这与拥有永不改变的URI的用意背道而驰。

3.主机名版本控制

该版本是主机名的一部分而不是URI,例如,https://v2.api.myapp.com/customers。当技术限制阻止基于URI或者Accept标头到API的正确后台版本时,将使用此方法。

备注:无论您选择哪个选项,API版本都只应包含主要编号。不需要小数字(即? /v1/customers,不是/v1.1/customers)。

实现版本控制的工具

使用工具和技术可以从根本上实现API版本控制过程。用市场上优秀的API编辑器将使技术开发团队能够在更短的时间内生成并切换更多的API版本,从而不断改进设计决策。

结合工具进行版本控制是大多数开发过程的重要组成部分。API设计领域中也有这种能版本控制的工具,实际上,全球范围内API服务领域中已经存在少量优秀的Web API设计工具。

现在,如EOLINKER、RAML、Swagger,都提供了出色的编辑工具来支持他们的语言。EOLINKER采用的是版本比照和重点标注提醒,可以清晰的切换、比照。RAML、Swagger采用的是版本切换,方便程度可能略逊一点。而且只有前者是支持中文的,后两种只支持英文语言。这些API编辑器都能轻松地实现API版本的控制,使得更容易在更短的时间内切换运行版本。

附上EOLINKER的官方网址:https://www.eolinker.com

附上Swagger的官方网址:https://swagger.io/

附上RAML的官方网址:https://raml.org/

最后的想法

请记住,API是与你的消费者链接的枢纽。打破旧的连接,就需要新版本。选择策略,制定计划,并与API使用者沟通该计划,这才是版本控制的最终目的。


参考资料:James Higginbotham,When and How Do You Version Your API?

原文地址:https://dzone.com/articles/when-and-how-do-you-version-your-api

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 对API进行版本控制的重要性和实现方式

发表回复