news 2026/5/18 18:34:10

第十八课实战:后端性能优化实战——一个接口从 2 秒到 90ms 的全过程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第十八课实战:后端性能优化实战——一个接口从 2 秒到 90ms 的全过程

目标:
不是讲概念,而是演示一次真实的性能优化过程
如何从一个 2 秒接口,优化到 90ms,并且每一步都有依据。


场景设定

接口:

GET /users?page=1&size=20

表数据量:50 万条
技术栈:Spring Boot + MySQL + Redis

初始状态(问题版本)

初始代码问题点

1)SQL 问题

SELECT * FROM user;
  • 无索引
  • 全表扫描
  • 返回 50 万行

2)接口问题

  • DTO 字段 30+
  • 返回整个 List
  • 打印全部日志

3)RPC 问题

for(User u : list){ rpcService.getScore(u.getId()); }

典型N+1 调用

初始压测结果

指标数值
P50300ms
P901200ms
P992100ms
CPU35%
内存稳定

结论:不是资源打满,是逻辑慢。

第一步:SQL 优化(最大头)

动作

1)加索引

CREATE INDEX idx_user_status_time ON user(status, create_time);

2)分页 + 字段裁剪

SELECT id,name,status FROM user WHERE status=1 ORDER BY create_time DESC LIMIT 20;

3)Explain 对比

优化前优化后
type=ALLtype=ref
rows=500000rows=120

SQL 优化后压测

指标数值
P99

2100 →420ms

第二步:接口层优化

问题点

  • 返回字段过多

  • 日志拖慢

  • 序列化重

动作

DTO 裁剪

class UserDTO { Long id; String name; }

日志采样

if(random()<0.01){ log.info("users:{}", list.size()); }

接口层优化后

指标数值
P99420 →180ms

第三步:RPC 优化(N+1 问题)

原始

for(User u : list){ rpc.getScore(u.id); }

改为批量

rpc.batchGetScore(ids);

RPC 优化后

指标数值
P99180 →130ms

第四步:JVM 优化

观察指标

  • Minor GC 频繁

  • 对象创建多

动作

  • 复用集合

  • 减少字符串拼接

  • 调整线程池

JVM 优化后

指标数值
P99130 →90ms
GC 次数-40%

全过程对比

阶段P99
初始2100ms
SQL 优化420ms
接口优化180ms
RPC 优化130ms
JVM 优化90ms

优化核心逻辑总结

先 SQL 再 接口 再 RPC 最后 JVM

实战中的关键判断

现象判断
CPU 不高却慢逻辑慢
P99 高极端请求问题
SQL rows 巨大索引问题
GC 多对象创建问题

工程经验总结

不要一上来做的事

  • 不要先加缓存

  • 不要先调 JVM 参数

  • 不要先加 MQ

应该先做的事

  • 看 P99

  • Explain SQL

  • 拆链路

  • 再优化

最终一句话

性能优化不是“调参”,而是“定位 → 分层 → 验证”的工程流程。

当你能把一个 2 秒接口优化到 90ms,
你就已经具备中高级后端工程师的实战能力了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/19 11:50:55

【ROS/ROS2与实时Linux系列】第六篇 `cyclictest`:实时性指标量化与分析

一、简介&#xff1a;为什么实时性指标量化至关重要&#xff1f;在 ROS/ROS2 应用中&#xff0c;实时性是确保系统稳定运行的关键因素。例如&#xff0c;在机器人导航、自动驾驶和工业自动化控制中&#xff0c;系统需要在极短时间内对传感器数据进行处理并做出决策。实时性指标…

作者头像 李华
网站建设 2026/5/17 6:30:38

ResNet十年演进

ResNet&#xff08;残差网络&#xff09; 的十年&#xff08;2015–2025&#xff09;&#xff0c;是从“解决深度神经网络训练难题”的学术突破&#xff0c;向“深度学习工业标准基座”&#xff0c;再到“通过 ConvNeXt 架构反击 Transformer”并最终实现“内核级实时视觉调度”…

作者头像 李华
网站建设 2026/5/9 3:48:48

ECS + ALB 健康检查配置指南

本文档详细说明 ECS 服务与 ALB 目标组健康检查的配置方法、常见问题及最佳实践。 一、架构概览 ┌─────────────────────────────────────────────────────────────────────────────────┐…

作者头像 李华