0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是API标准化?

jf_WZTOguxH 来源:AI前线 作者:Thiyagarajan Kamaraj 2022-11-02 13:51 次阅读

什么是 API 标准化?

API 设计就是创建一个有效的接口,使你可以更好地维护和实现 API,同时使消费者能够轻松地使用这个 API。

一致的 API 设计意味着,在组织或团队中对所有 API 及其公开的资源进行标准化设计。它是开发人员、架构师和技术作者共同遵守的蓝图,可以保证在 API 使用过程中品牌和体验的一致性。风格指南旨在确保 API 设计和实现方式的一致性,组织就是用它来标准化设计。下面是比较流行的两份风格指南:

  1. 微软 REST API 指南

  2. 谷歌 API 设计指南在业余项目里,为了开发出一致的 API,并遵循 API 开发的行业最佳实践,我经常参考这本风格手册。

为什么要标准化?

清晰的设计方法可以确保 API 与业务需求相一致。API 越标准,歧义就越少,合作成果就越多,质量就更有保障,API 的采用也会相应增加。

清晰一致的 API 设计标准是良好开发体验和消费体验的基础。它们使开发人员和消费者都能够快速有效地理解 API,缩短学习曲线,并按照一套指南进行构建。

API 标准化还可以改善团队协作,提供提升准确性和降低延迟的指导原则,有助于降低总开发成本。标准对于 API 策略的成功如此重要,以至于许多科技公司(如微软、谷歌和 IBM)以及行业组织(如 SWIFT、TMForum 和 IATA)都使用并支持 OpenAPI 规范(OAS),并将其作为定义 RESTful API 的基本标准。

如果不进行标准化,那么个体开发人员在设计过程中就可以随意选择。虽然我们鼓励创造,但如果没有适当的风格指南,很快就会变得混乱。

如果不进行标准化,那么组织就无法在 API 设计和交付过程中提供质量保证。强化设计标准有助于提升预测成功结果的能力,让组织能够在保证质量的前提下快速扩展 API 开发。

API 标准化之旅

如果没有一个正式的流程来强化标准化,就不可能成功地扩展 API 设计和开发过程,也不可能符合监管和行业标准。API 设计风格指南提供了内外部团队在构建 API 定义和重用资产时开展协作所需的“护栏”。

最初,组织在内部以 PDF 或 Wiki 的形式发布 API 指南,供所有人参考,并制定相应的流程以确保团队遵循设计指南。确保开发一致性的一种方案是在 API 开发期间进行人工评审。

API 以 OpenAPI 格式指定,并在版本控制系统中维护,API 定义可以遵循与其他代码工件相同的评审过程。开发人员可以为 API 更改创建 pull 请求,并让同事提供反馈。这个过程是手动的,是保障治理以及确保遵循 API 指南的有效方法,但与所有手动过程一样,它容易受人为错误所影响,而且有时候不及时。

等待同事评审 API 更改可能会导致周期变慢,对开发人员的工作效率产生不利的影响,特别是涉及到评审过程中可以自动化的方面时。当组织规模扩大,更多的开发人员开始参与 API 开发时,这个过程也无法扩展。在这种情况下,可以提供 API 自动评审的左移法就很有用了。就像我们对其他工件所做的那样,借助一些自动化工具或分析器尽早获得反馈,这样最好了。

什么是左移法?

术语“左移”指的是软件开发中的一种实践。在这种实践中,团队会比以往更早地开始测试,帮助自己聚焦质量,致力于问题预防而不是检测。左移的目标是提高质量,缩短漫长的测试周期,并降低在开发周期结束时(或者更糟,在生产环境中)出现令人不快的意外情况的可能性。

Open API 验证器

说到 OpenAPI 分析器,我见过一些。它们将 API 风格指南转换为一组规则,并根据 Open API 规范进行验证。这些分析器允许你根据组织风格指南自定义规则。一个名为 Zally 的分析器引起了我的注意,它是一个用 Kotlin 编写的工具,由 Zalando 开源。OpenAPI 风格指南验证器的工作流程如下:

将 API 标准或风格指南表示成一组规则。这里有 Zalando 提供的一份指南;

根据 OpenAPI 编写 API;

像 Zally、SonarQube、Spectra 这样的检测工具可以验证开发人员编写的 OpenAPI 规范是否符合第 1 步中定义的规范规则。

Zally 是什么?

Zally 是一个简单易用的 API 分析器。它的标准配置是根据 Zalando RESTful 指南中定义的规则检查 API,对任何人来说都是开箱即用的。它具有可扩展性,允许我们添加自己的规则集。它还提供以下特性:

  • 根据需要在服务器端启用 / 禁用规则;

  • 接受 JSON 和 YAML 格式的 Swagger V2 和 OpenAPI V3 规范;

  • 可以编写并插入自己的规则;

  • 直观的 Web UI 显示了实现的规则和规范验证的结果;

  • 使用 Web 钩子集成 GitHub,验证每个 pull 请求中的 OpenAPI,并在评论中回显违规情况。

Zally Gradle 插件背后的动机

虽然 Zally 的编写方式更具可扩展性和可定制性,但我觉得,我们仍然可以进一步改进 Zally 当前的验证工作流,缩短开发反馈循环。由于 Zally 缺少像 checkstyle、ktlint、spot bug 这样的插件,所以我在使用 Zally 时遇到了以下几个痛点:

  • 为了使用 CLI 工具,开发人员需要在本地或远程系统上托管 Zally 服务器;

  • 开发人员需要切换运行 CLI 工具的上下文,或是额外做一些工作,将 CLI 配置为 Maven/Gradle 构建过程的一部分,前提是第一条已经满足;

  • 在每个 pull 请求中使用 GitHub 集成组件验证 API 会增加反馈循环时间。所有这些都增加了向开发人员反馈的时间,并且还有托管 Zally 服务器的人工开销。所以我决定编写自己的 Gradle 插件,它既可以集成在本地开发环境中,也可以集成在 CI 工具中,帮助我验证和提取不同格式的验证结果。

定制 Zally 插件

zally-gradle-plugin 是一个用 kotlin 编写的 Gradle 插件,可以集成到构建脚本中。该插件根据规则集验证规范,并提供 JSON 和 HTML 格式的报告。

该项目包含一个示例任务配置:

// settings.gradle.kts
pluginManagement {
    repositories {
        gradlePluginPortal()
        mavenLocal()
    }
}


// build.gradke.kts
plugins {
    id("io.github.thiyagu06") version "1.0.2-dev"
}


zallyLint {
    inputSpec = File("${projectDir}/docs/petstore-spec.yml")
    reports {
        json {
            enabled = true
            destination = File("${rootDir}/zally/violation.json")
        }
        rules {
            must {
               max = 10
            }
        }
    }
}


//execute task
./gradlew clean zallyLint


```
```
Run ZallyLint task
./gradlew zallyLint

有了这个 Gradle 插件,我就可以在 API 开发过程中实时获得反馈。这使我能够在进入手动检查步骤之前修复 API 的问题。该插件还可以与 CI 作业集成,用于风格指南的检查验证。因为所有开发团队都使用相同的规则,所以组织就可以为用户提供更加一致的 API。该方法大致有如下好处。该插件提供了一个选项,可以将违规报告导出为 JSON 和 HTML 格式。它还提供了一种简单的规则配置方法,用于定义每个严重性级别下规范中可以存在的最大违规数。

可以将 JSON 格式解析并导出到任何数据库中,用于计算 API 设计兼容性得分,并构建一个仪表板,共享给更广泛的组织,作为 API 标准化方案的决策依据。同样,HTML 报告也可以导出到 S3 桶或谷歌云存储,并以网站的形式提供给更广泛的受众。

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 软件开发
    +关注

    关注

    0

    文章

    614

    浏览量

    27356
  • API
    API
    +关注

    关注

    2

    文章

    1499

    浏览量

    61989
  • 分析器
    +关注

    关注

    0

    文章

    92

    浏览量

    12493

原文标题:简化跨微服务重用,API 标准化过程中的左移法

文章出处:【微信号:AI前线,微信公众号:AI前线】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    三星与SK海力士携手推进LPDDR6-PIM产品标准化

    据外媒最新报道,韩国两大存储芯片巨头三星电子与SK海力士已正式结盟,共同致力于推动LPDDR6的存内计算(Processing In Memory,简称PIM)产品的标准化进程。此举旨在加速人工智能
    的头像 发表于 12-03 10:42 221次阅读

    芯海科技引领智能浪潮:标准化单键压力按键解决方案赋能终端创新

    芯海科技凭借其敏锐的市场洞察力和深厚的技术积累,推出了“标准化单键压力按键”解决方案,为终端客户带来前所未有的便捷与创新。
    的头像 发表于 11-28 09:34 207次阅读
    芯海科技引领智能<b class='flag-5'>化</b>浪潮:<b class='flag-5'>标准化</b>单键压力按键解决方案赋能终端创新

    CAN技术的标准化之旅

    国际标准化组织 (ISO)于2024年5月27日发布了文件ISO 11898-1:2024;在此之前,于2024年3月22日,发布了文件ISO 11898-2:2024。自此,CAN (控制器局域网络)技术的所有协议及收发器完全纳入ISO标准,标志着CAN
    的头像 发表于 11-07 11:48 396次阅读

    浅谈虚拟电厂标准化现状与需求分析

    了虚拟电厂各环节的标准化现状,依据自上而下和自下而上的系统工程方法,结合引导性、协调性、系统性和开放性的虚拟电厂标准体系构建原则,设计了涵盖15个子类、52个标准系列的体系架构,并基于未来需求分析提出了重点布局
    的头像 发表于 10-16 15:35 432次阅读
    浅谈虚拟电厂<b class='flag-5'>标准化</b>现状与需求分析

    博世携手Tenstorrent共研汽车芯片标准化方案

    Tenstorrent的高管透露,德国工业巨头博世将与美国的芯片初创企业Tenstorrent携手,共同打造一个平台,旨在标准化汽车芯片的构建模块——Chiplet
    的头像 发表于 10-14 16:31 682次阅读

    wms智能仓储管理系统标准化流程

    wms智能仓储管理系统标准化流程的标准化流程通常包括以下几个主要步骤: 需求分析:与客户充分沟通,了解其仓储管理需求和业务流程,确定系统功能和特性的需求,制定系统开发和实施计划。 系统设计:根据需求
    的头像 发表于 10-14 16:22 242次阅读

    国际标准化组织实验室设计技术委员会及中关村标准化协会 莅临东舟技术指导创新发展工作

    2024年6月4日,中关村标准化协会秘书长黄群、国际标准化组织实验室设计技术委员会(ISO/TC336)秘书处主任杨廷一行莅临东舟技术。ISOTC336全称国际标准化组织实验室设计技术委员会(ISOTechnicalCommit
    的头像 发表于 06-24 13:44 649次阅读
    国际<b class='flag-5'>标准化</b>组织实验室设计技术委员会及中关村<b class='flag-5'>标准化</b>协会 莅临东舟技术指导创新发展工作

    德力西电气顺利召开国网标准化柜体技术交流会!

    为了以标准数字创新服务电网高质量发展,5月24日,德力西电气举办的国网标准化柜体技术交流会在郑州隆重召开。
    的头像 发表于 05-28 10:43 618次阅读

    易华录参编《数据要素流通标准化白皮书(2024)》正式发布

    为加快推动我国数据标准化工作,5月25日,由国家数据局主办、中国电子技术标准化研究院承办的第七届数字中国建设峰会“数据标准化和数据基础设施分论坛-数据标准化专场”成功召开。
    的头像 发表于 05-27 09:45 787次阅读
    易华录参编《数据要素流通<b class='flag-5'>标准化</b>白皮书(2024)》正式发布

    谷歌智能家庭Home API平台推送,兼容Matter设备并支持自动家庭场景应用

    谷歌指出,开发人员有望利用此API创建一个标准化的、跨平台且依赖于谷歌智能家居“自动引擎”的App。消费者只需使用这一款App便能对各类智能家居设备进行管理。
    的头像 发表于 05-17 14:55 605次阅读

    Ansys与舍弗勒合作共同实现产品开发流程的数字标准化

    Ansys仿真解决方案将助力舍弗勒在整个企业内实现产品开发流程的数字标准化
    的头像 发表于 02-25 14:01 740次阅读

    华为被传试图放缓6G标准化进程

    有外媒报道称“有传言称,华为试图放慢6G标准化进程,直到中国在6G产品所需的先进芯片的国产开发方面取得进一步进展。
    发表于 02-21 10:04 469次阅读

    Type-C接口标准化背后的欧盟意图

    在当今数字潮流中,欧洲联盟(欧盟)日益关注电子设备充电接口的标准化问题。最近,欧盟宣布将全面采用Type-C接口,这一决定引起了广泛关注。Type-C接口的标准化将对欧洲和全球的电子设备产业带来深远影响,涉及技术创新、用户体验
    的头像 发表于 02-02 14:24 466次阅读
    Type-C接口<b class='flag-5'>标准化</b>背后的欧盟意图

    农村供水工程如何实现标准化物联网管理  

    根据《水利部办公厅关于推进农村供水工程标准化管理的通知》《水利部办公厅关于做好2023年度农村供水工程标准化管理工作的通知》要求,国家水利部于近日公布了全国80处通过标准化管理评价的农村供水工程名单
    的头像 发表于 01-25 10:42 440次阅读
    农村供水工程如何实现<b class='flag-5'>标准化</b>物联网管理   

    苏州电科院荣膺中电协“2023电器工业标准化示范企业”称号

    近日,苏州电器科学研究院股份有限公司荣获中国电器工业协会发布的“2023电器工业标准化示范企业”称号。苏州电科院的入选及最终获评,充分体现了公司作为行业头部优势企业,在标准化体系建设和标准引领示范
    的头像 发表于 12-28 16:20 688次阅读
    苏州电科院荣膺中电协“2023电器工业<b class='flag-5'>标准化</b>示范企业”称号