• API


    1
    前言
    
    随着微服务的越来越流行,越来的越多的公司开始实行微服务架构,相对于单一应用架构,微服务将复杂性拆分并且打散到一个个粒度更加细分的应用中,极大了减少了开发中单个服务的复杂性,开发人员只需要面向专注单一业务场景编程,从技术开发角度,单一服务代码量上减少很多,从业务角度上,业务复杂性的降低降低了需求的沟通成本,然而,整体业务复杂性依然存在,当我们需要接入或者依赖其他服务时,通常作为接入方来说,我们不需要深入了解服务提供方的业务,此时API成为了开发人员间的沟通语言。 良好的API设计,能极大的减少沟通成本,甚至有时候可以代替文档,尤其是对于基础性服务来说,服务的可扩展性有时候体现在API的可扩展性,我曾经参与过一个基础业务微服务的业务升级,由于旧版本的API划分不够清晰,部分API存在重复性,后面不得不对大部分API进行重构(替换为新版本的API),仅仅在服务消费方升级这个阶段就持续1-2个月之久,在这个过程中也不断对API设计中存在的一些问题以及应该遵循哪些原则进行了一些思考。
    2
    API先行
    
    在敏捷开发的大浪潮下,产品上通常要求快速迭代,面对一个新的需求,如果需要开发新的接口,通常在表结构完成设计后,开发人员就需要完成API设计并交付消费方(即服务的调用方或者依赖方,文中其余部分均表示此含义),在技术联调前,消费方可以Mock接口来完成调试。所以通常来说,API先与服务交付,之后再完成编码,测试,调试等工作。当然,由于可能在需求细节,技术实现方面可能在实现过程中发现需求需要调整,或者API接口的调整,最初版本的API可能是不成熟的,导致我们经常在API调整或者演化过程中在API维护方面存在很多遗漏,所以API最初交付后的维护是持续性的工作。
    3
    API设计常见问题
    
    在我们设计API过程中由于存在经验的缺失,或者由于多次交接,或者由于经历多次需求的变更,导致服务的API慢慢腐化,带来以下常见的问题。被遗忘的注释
    注释通常描述了API的功能以及参数说明,以及如何接入,甚至给出简单示例,过于详细的注释会带来一定的反作用,例如因为新需求带来了内部逻辑的调整,但是由于未及时对API的注释进行更新,会给新接入的调用方带来潜在的风险。所以不仅仅需要为API提供完整清晰的注释,当内部逻辑变更时,作为开发人员通常也需要评估API层面的变更,包括注释。
    接口数量持续膨胀
    有很多原因带来接口数量的膨胀,可能是接口升级,但是旧接口无法直接下线,所以会提供一个功能类似的新接口;可能是新接管一个服务由于对业务不了解,面对新需求直接开发新接口;可能是接口分类划分不合理,或者数据模型混乱导致API划分混乱,出现API功能重复,最后导致一个场景多个API接口都可以满足,这样很明显是应该避免的。解决这些问题都需要建立在对业务充分理解的基础上,下文的设计原则会针对这类问题给出解决方案。
    
    缺乏有效测试
    很多开发人员往往忽略对于接口的测试,无论是内部逻辑细节的单元测试,还是接口层面的测试,都是服务健壮性的一个有效保证,如果无法对接口进行有效测试,不仅是不负责任的提现,而且还会经常被线上bug困扰。
    4
    API设计的原则
    
    1. 简单且专注在面向对象设计原则中,第一条是单一职责原则,同样适用于API设计,我们的主体对象就是业务模型,API就是封装内部逻辑后对外界开放的功能。保证API的简单和职责单一,能够避免解决上文中提到的接口数量膨胀问题。那如何才能实现API职责单一,需要我们在定义接口时能够准确识别出接口之间的关联性和边界,对于API如何划分可以通过以下角度    1. 按照业务主体划分,不一样的业务主体采用不一样的接口类    2. 查询类和修改类的接口分离;通常来说我们对于数据的查询场景远大于修改的场景,而且查询有多种多样的业务场景,对于数据的修改请求通常来源于业务后台人员对数据进行修改,此时的业务逻辑也通常会更加特殊(例如有很多额外数据校验),所以建议修改类和查询类API尽量分离,甚至可以将业务配置后台类查询和普通业务查询分离以至于能够适应各自的业务变更。一个单一接口的场景是基于业务抽象后专注于某一个场景并且互相不重合的,这样才能保证接口的粒度足够小,尤其是对于基础类服务,接口粒度的划分能保证接口是纯粹的且互相独立的,这样才不至于在需求变化是涉及过多接口的变动(除非是对业务模型有较大的调整),另外要说明的是,内部逻辑的业务数据模型(POJO类)和API数据模型(DTO)有时候出现差异,否则可能需要消费者理解服务的业务模型才能正确的使用接口,这就要求在API设计中开发人员需要明确应该提供哪些数据模型给消费者,在此前提下更加有助于我们保证单一接口的专注。2. 良好的注释注释应该包含哪些;
    接口的使用场景,参数的说明,在接口类说明中可以给出接口文档链接地址,方便调用方查看
    参数的说明;
    包含参数代表的含义,参数的类型按照Javadoc link
    

      

  • 相关阅读:
    Civil 3D .NET二次开发第11章代码升级至2018版注意事项
    创建道路曲面
    ObjectARX® for Beginners: An Introduction
    mshcMigrate制作的mshc文件中有链接打不开
    Word 2013无法发布文章到博客园
    ionic 安装插件报错:源文本中存在无法识别的标记
    typescript文件中 使用回调函数无法调用函数外的变量和方法的办法
    ionic2---自定义插件
    angular2----使用swiper做轮播图
    angular2----router
  • 原文地址:https://www.cnblogs.com/gzhbk/p/13500150.html
Copyright © 2020-2023  润新知