API 接口性能优化管理

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 本文探讨了国内项目中常见的接口性能问题及其优化策略。面对紧张的工期与多样的编码习惯,文章系统地分析了性能需求、确立了性能标准,并详细列举了常见的性能瓶颈,如循环调用数据库、不当的SQL编写及数据处理方式等。针对这些问题,提出了包括配置调整、代码改进、数据库优化、引入缓存机制、利用异步处理等在内的多种解决方案,并强调了可观测性工具的重要性。通过这些方法,能有效提升接口性能和用户体验。

前言

国内项目普遍出现工期紧、工作量大、多人协作开发编码习惯不同,能力也参差不齐等多种因素,导致接口在上线后性能不满足预期。

本文从接口性能需求分析、接口性能准出标准、接口性能常见问题以及性能优化策略等多个方面,系统地完成接口性能优化的工作。

同时在项目交付过程中,可以通过 Code Review 、 技术债务等方式提前进行一部分接口性能的识别和优化,因为越复杂的项目拖到最后调整的代价越大。

接口性能需求分析流程

分析要点:

  1. 列举系统中核心场景,梳理出 API 接口清单,询问外部系统是否支持压测,防止将其它系统压崩
  2. 结合系统用户数、请求量、现有数据量以及未来几年的增长量,确定接口的性能指标,比如:TPS 等
  3. 准备预生产环境,进行 API 接口的压测
  4. 统计接口的 TPS、响应时间、CPU 占有率、内存占有率、接口错误率等数据指标
  5. 筛选不达标的接口,通过 APM 应用性能工具和调用链路查看耗时情况
  6. 根据具体情况进行 API 接口优化

接口性能的准出标准

以一个中等复杂软件系统为样例的接口性能准出标准:

接口性能优化方案

接口性能常见问题

代码结构不合理

  1. 循环调用数据库或者外部系统,导致耗时长
  2. 查询复杂单据详情时,不考虑实际情况,一股脑的把所有关联的数据查询出来
  3. 一次性加载巨量数据到内存中进行处理,耗时长或者 OOM 内存溢出
  4. 接口返回大量数据,接口处理时间长,网络传输时间长,前端页面处理数据时间长
  5. 执行数据库保存时,经常使用默认的 saveAll,导致一条条插入到数据,耗时长
  6. 大量非必要、不阻塞主流程的业务逻辑写在一起导致长事务、数据一致性等问题
  7. 不阻塞主流程或着可延迟处理的外部系统调用,都使用同步调用的方式

SQL 编写不合理

  1. SQL 执行语句没有新建对应的索引
  2. SQL 执行语句包含隐式类型转换、最左匹配失效、使用函数或表达式等导致慢 SQL
  3. SQL join 了超过了三张及以上表
  4. 小表连大表,left join 无索引,导致全量扫描大表情况
  5. 深分页问题
  6. order by 走文件排序
  7. group by 使用了临时表
  8. 海量数据时count很慢,因 MySQL InnoDB count会遍历所有数据,计数准确但是性能较低

其他

  1. 请求高频、数据变更频率低,比如:基础数据、权限数据等,高并发下延迟大,可考虑使用缓存
  2. MySQL 数据库并发顶不住的时候,比如:点赞等,可考虑使用 Redis 等先缓存扛着后同步到 MySQL
  3. ......

性能优化策略

1️⃣ 配置优化

  • JVM 参数
  • 数据库连接池参数
  • 硬件参数

2️⃣ 代码优化

  • 减少外部资源重复调用
  • 按需查询所关联的数据资源
  • 批量操作数据库

3️⃣ 池化技术

  • 使用线程池处理业务逻辑
  • 使用对象池复用已有对象
  • HTTP 连接池访问外部系统

4️⃣ 数据库优化

  • 使用索引 、 现有索引优化
  • SQL 编写不合理,避免太多表 Join、临时表、全表扫描
  • 避免大事务,减少死锁
  • 锁力度避免过粗,减少锁占用超时
  • 深分页问题:1)通过ID记录标签 2)先深分页查询id,再inner join

5️⃣ 异步思想

  • 耗时操作,考虑异步执行
  • 同步远程调用由同步改为异步
  • 非阻塞主流程业务改为异步

6️⃣ 缓存策略

  • Nginx 缓存
  • Redis 缓存 / 分布式缓存
  • 本地缓存
  • 注意数据一致性、缓存穿透、缓存击穿、大 Key 等问题

7️⃣ 大数据量处理

  • 接口返回的数据量过大:分层分级返回、分批次返回、分页返回、压缩数据、延迟加载等
  • 大量数据加载到内存,导致 OOM,可考虑分批次处理
  • 海量数据时,count 查询慢,建议和分页列表接口分离
  • 千万级别数据,可考虑冷热数据分离、数据库表分区、分库分表等
  • 海量数据处理,考虑使用 NoSQL

8️⃣ 可观测性 & 工具

  • 日志平台
  • 分布式追踪
  • APM & 告警平台:CPU、内存监控
  • 数据库:Explain语句(MySQL)
  • 性能诊断工具:Jstack 查看进程信息

小结

API 接口优化是一个持续的过程,需要根据实际的业务需求和系统负载不断进行调整和优化。通过以上方法,可以显著提高API的性能、可用性和用户体验。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
API 数据处理 开发者
Polars中的急性与惰性API:性能优化与数据处理策略
Polars中的急性与惰性API:性能优化与数据处理策略
31 1
|
2月前
|
缓存 Java API
API接口性能优化管理
在数字化时代,API性能优化对于提升软件效率和用户体验至关重要。本文介绍了多种优化方法:配置优化包括调整JVM参数等;代码层面减少重复调用并批量操作数据库;池化技术如线程池和HTTP连接池能有效利用资源;数据库优化通过索引提高查询速度;异步处理则使主流程业务不受阻塞;缓存策略如Redis缓存减少数据库访问;可观测性工具如日志平台和APM帮助监控性能。综合运用这些方法,可根据业务需求持续调整优化,显著提升API性能及用户体验。
|
7月前
|
缓存 负载均衡 API
微服务架构下的API网关性能优化实践
【5月更文挑战第10天】在微服务架构中,API网关作为前端和后端服务之间的关键枢纽,其性能直接影响到整个系统的响应速度和稳定性。本文将探讨在高并发场景下,如何通过缓存策略、负载均衡、异步处理等技术手段对API网关进行性能优化,以确保用户体验和服务的可靠性。
|
7月前
|
缓存 监控 API
|
7月前
|
消息中间件 缓存 API
微服务架构下的API网关性能优化实践
在现代的软件开发中,微服务架构因其灵活性和可扩展性被广泛采用。随着服务的细分与增多,API网关作为微服务架构中的关键组件,承担着请求路由、负载均衡、权限校验等重要职责。然而,随着流量的增长和业务复杂度的提升,API网关很容易成为性能瓶颈。本文将深入探讨API网关在微服务环境中的性能优化策略,包括缓存机制、连接池管理、异步处理等方面的具体实现,旨在为开发者提供实用的性能提升指导。
|
7月前
|
缓存 负载均衡 API
如何对阿里巴巴中国站按关键字搜索商品 API 进行性能优化和负载均衡?
索引优化:对于搜索请求,数据库的索引优化是至关重要的。为常用的搜索关键字建立合适的索引,可以显著提高查询效率。同时,要根据搜索需求和数据更新频率,定期优化和维护索引
|
缓存 JSON 运维
深入探讨API调用性能优化与错误处理
随着互联网技术的不断发展,API(应用程序接口)已经成为软件系统中重要的组成部分。而优化API调用的性能以及处理错误和异常情况则是保障系统稳定性和可靠性的关键。本文将从以下几个方面来探讨如何进行性能优化和错误处理。
|
SQL 消息中间件 缓存
|
存储 SQL 缓存
API接口性能优化总结
在web开发过程中,经常会遇到接口RT高的情况,除了通过监控事后优化的方式,我们还需要掌握一些常用的手段,避免写出慢的接口。从前端发起调用到后端一般经过网关层、应用层、存储层。每一层都可以优化,本篇文章主要是应用层优化。
404 0
|
关系型数据库 API 数据库
参与 API 创新应用大赛,体验RDS CloudDBA数据库性能优化 API
阿里云的RDS数据库,有开发者所需要的一系列的功能,但很多功能很多开发者可能并没有使用过。这里,介绍一个RDS比较有用的功能:CloudDBA数据库性能优化 API。
13148 0