当前位置: 首页 > news >正文

MuleSoft 中的细粒度与粗粒度 API

API 设计是一个令人着迷的话题。API 设计的一个重要方面是根据 API 的特性和功能确定正确的“大小”。所有建筑师都必须在某个时候解决过这个问题。在本文中,我将尝试对我们在获得“正确的”粒度 API 之前需要考虑的各种参数进行一些深入的探讨:

可维护性: 首先想到的是 API 的可维护性。粗粒度的 API 很难维护。随着 API 使用者需求的增长,添加更多的实现变体或参数将变得困难。

管理:在MuleSoft中,我们可以使用API​​ Manager来单独管理每个API。这意味着我们可以根据需要对每个 API 实施 IP 白名单、IP 黑名单、基于 SLA 的速率限制、JSON 威胁防护等安全策略。由于每个安全策略都会增加一点延迟,因此这成为一个重要的考虑因素。 

错误处理: 您可以在不同的 API 中应用更清晰的错误处理。这也可能导致为不同的 API 定义 MuleSoft 警报

可部署性:细粒度的 API 易于部署。如果正确遵循版本控制,我们可以快速部署较小的 API,并以更敏捷的方式向市场推出功能。这通常会缩短创新周期,因为更改和新功能可以更快地部署到生产中

可扩展性:Cloudhub工作线程独立分配给每个API实现,因此可以根据每个API实现的特定需求进行调整(缩放)

资源:每个 API 实现无论有多小,都会消耗最少的一组资源(CloudHub 工作线程),而更多的 API 实现(即使它们更小)通常
意味着总体资源使用量更高

复杂性:较小的 API 和 API 实现更简单,因此更容易理解和维护。与更大且更少的 API 和 API 实现相比,它们还会导致应用程序网络中可见更多与 API 相关的资产以及越来越复杂的交互(API 调用)。然而,由于这些 API 之间的交互,具有许多细粒度 API 的大型系统将非常复杂

延迟:每个额外的 API 调用至少会增加少量延迟,因此较小的 API 会导致较高的总体延迟,通常必须通过缓存等来缓解。对于体验 API,请仔细考虑此参数。移动订单 API 比基于 Web 的订单 API 对延迟更加敏感。

故障模式:每个额外的 API 调用都是应用程序组件之间的额外远程交互
,必须解决其潜在故障。另一方面,粗粒度的 API 可能会成为单点故障。

组织结构:在任何大型组织中,不同的业务线如果具有不同的限界上下文,则必须相互交互。通过细粒度 API,每个 API 都可以独立于所有其他 API 实现而实现,前提是 API 实现之间的应用程序接口(以 API 规范的形式)已达成一致。这意味着通过细粒度的 API 和 API 实现,团队组织和实现工作的并行化将更加灵活。

重要的是要记住,这两种方法的整体功能保持不变,但最终使用细粒度 API 方法会获得更多的端点。作为开发人员,您可以放心,您的代码将更加结构化,因为每个 API 对应不同的操作。在大多数情况下,您都需要这两种 API。

http://www.lryc.cn/news/251889.html

相关文章:

  • 【笔记】2023最新Python安装教程(Windows 11)
  • Android Wifi断开问题分析和802.11原因码
  • 【Cell Signaling + 神经递质(neurotransmitter) ; 神经肽 】
  • 当springsecurity出现SerializationException问题
  • [SaaS] 广告创意中stable-diffusion的应用
  • 第八节HarmonyOS @Component自定义组件的生命周期
  • 【Openstack Train安装】五、Memcached/Etcd安装
  • 29 kafka动态配置
  • JIRA部分数据库结构
  • RK3568平台开发系列讲解(Linux系统篇) dtb 到 device_node 的转化
  • 屏幕的刷新率和分辨率
  • 面试官:请说说JS中的防抖和节流
  • [足式机器人]Part4 南科大高等机器人控制课 Ch00 课程简介
  • SSM项目实战-登录验证成功并路由到首页面,Vue3+Vite+Axios+Element-Plus技术
  • Python----网络爬虫
  • 【微信小程序】上传头像 微信小程序内接小程序客服
  • 【c++随笔15】c++常用第三方库
  • 数据结构 | 查漏补缺之ASL、
  • 泊车功能专题介绍 ———— 汽车全景影像监测系统性能要求及试验方法(国标未公布)
  • 【Linux】第二十六站:软硬链接
  • 开源播放器GSYVideoPlayer + ViewPager2 源码解析
  • 重启路由器可以解决N多问题?
  • Python WebSocket 客户端教程
  • 洛谷 P2984 [USACO10FEB] Chocolate Giving S
  • 【专题】【数列极限】
  • oracle基础系统学习文章目录
  • 长度最小的子数组(Java详解)
  • 计算机组成学习-数据的表示和运算总结
  • 目标检测YOLO系列从入门到精通技术详解100篇-【目标检测】机器视觉(基础篇)(八)
  • 【4】基于多设计模式下的同步异步日志系统-框架设计