微服务设计原则——高性能:批量

能批量就不要并发。

如果调用方需要调用我们接口多次才能进行一个完整的操作,那么这个接口设计就可能有问题。

比如获取数据的接口,如果仅仅提供getData(int id)接口,那么使用方如果要一次性获取 20 个数据,它就需要循环遍历调用我们接口 20 次,不仅使用方性能很差,也无端增加了我们服务的压力,这时提供一个批量拉取的接口getDataBatch(List<Integer> idList)显然是必要的。

对于批量接口,我们也要注意接口的吞吐能力,避免长时间执行。

还是以获取数据的接口为例:getDataList(List<Integer> idList),假设一个用户一次传 1w 个id进来,那么接口可能需要很长的时间才能处理完,这往往会导致超时,用户怎么调用结果都是超时异常,那怎么办?限制长度,比如限制长度为 100,即每次最多只能传 100 个 id,这样就能避免长时间执行,如果用户传的 id 列表长度超过 100 就报异常。

加了这样限制后,必须要让使用方清晰地知道这个方法有此限制,尽可能地避免用户误用。

有三种方法:

  • 改变方法名,比如getDataListWithLimitLength(List<Integer> idList)
  • 在接口说明文档中增加必要的注释说明。
  • 接口明确抛出超长异常,直白告知主调。
相关推荐
一个帅气昵称啊23 分钟前
在.NET中如何优雅的使用DotNetCore.CAP实现分布式事务,事件总线和消息最终一致性
分布式·微服务·.net
拾忆,想起24 分钟前
Dubbo序列化方式全解析:从原理到实战的性能优化指南
服务器·网络·微服务·性能优化·架构·dubbo
7***n7536 分钟前
后端在微服务中的Traefik
微服务·云原生·架构
n***271944 分钟前
SpringCloud 微服务框架
spring·spring cloud·微服务
ByNotD0g2 小时前
Golang开发项目学习
学习·微服务·云原生·golang
文慧的科技江湖25612 小时前
充电桩管理平台 - 经营管理核心逻辑——> 慧知开源充电桩平台(慧知管家)
微服务·开源·充电桩·ocpp·管理平台·经营管理
6269602 小时前
微服务负载均衡导致新增的字段时有时无的问题排查与解决/(ㄒoㄒ)/~~
微服务·架构·负载均衡
刘一说2 小时前
Nacos 配置加载优先级详解:Spring Cloud Alibaba 微服务配置管理的核心机制
微服务·云原生·架构
曾经的三心草2 小时前
微服务的编程测评系统-linux部署指令
linux·微服务·架构
逻极2 小时前
从单体到微服务:我们如何将Python Web应用性能提升3倍
python·微服务·web