Pau*_*ill 6 c# versioning asp.net database-versioning asp.net-web-api
所以我花了几个小时来浏览Web API版本控制的所有真正奇妙的建议.我最喜欢的一些,对于那些和我一样有趣的人,没有特别的顺序:
http://www.troyhunt.com/2014/02/your-api-versioning-is-wrong-which-is.html
http://www.pluralsight.com/courses/web-api-design
http://www.pluralsight.com/courses/implementing-restful-aspdotnet-web-api
因此,所有这些建议都非常有助于设计API本质上的"前端".我们可以对API调用进行版本控制......现在,我正在努力解决这个问题.
对于拥有多个产品(这是一个新产品)的公司来说,这是一个大量数据驱动的应用程序.一些需要长期支持API调用的大客户,一些希望获得最新版本的小客户.我们可以使用类似于里程碑/长期支持版本的API来管理.大.
但在实践中,这将变得非常混乱,非常快.我们一直在努力将我们自己的网站,beta内部/外部API,存储库层以及甚至是要启动的SDK分层.我们将每个版本分成不同的分支,但它是SAAS - 我们托管数据库.因此,我们不仅能够对API调用进行版本控制 - 而且还包括其下的所有内容.业务逻辑,存储库和数据库.我们甚至没有开始进行单元/集成测试.
因此,尝试并且可能失败只在这里提出一个问题.
是否有一个合适的模式来构建一个分层的,数据驱动的.NET应用程序来应对多个版本?
具体来说,数据库将如何更改以及如何构建通用堆栈以对其进行全部版本化.我的一些想法包括:
我们有相当数量的开发人员,无论我写了多少ace文档,实际上它只会在某些东西不起作用时被读取.因此,理想情况下,开发人员必须尽可能明显地明白这一点.
小智 2
不存在适合所有情况的完美解决方案,无论是否由数据驱动。
这确实很难回答。最好的选择是使用多种版本控制策略。
例如,如果数据库更改只是添加新列,则旧版本的 API 可以忽略新列。
如果数据库更改意味着您必须完全重写存储库层,那么您可能需要创建一个新的存储库和新的控制器,而不仅仅是对 API 方法进行版本控制。然后在端点上,您可以对路由进行版本控制,或者消费者可以调用替换端点。
如果 API 的各个级别都有显着的变化,那么使用单独的虚拟目录在 IIS 中进行版本控制可能是您的解决方案(并且这可能在源代码管理中具有相应的分支或标签,仅用于支持错误/修复)。
文件夹/命名空间的想法可能会让开发人员感到非常困惑,所以我会避开它。路由(即[Route("/v4/Orders")])可能是处理它的更好方法。同样,这取决于代码量和更改的性质。
| 归档时间: |
|
| 查看次数: |
1401 次 |
| 最近记录: |