news 2026/3/11 16:49:21

第十八课实战:后端性能优化实战——一个接口从 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/3/3 23:22:51

LSTM十年演进

长短期记忆网络&#xff08;Long Short-Term Memory, LSTM&#xff09; 的十年&#xff08;2015–2025&#xff09;&#xff0c;是一段从“序列建模的绝对统治者”到“被 Transformer 挑战”&#xff0c;再到“通过 xLSTM 实现史诗级复兴”的传奇历程。 这十年中&#xff0c;LS…

作者头像 李华
网站建设 2026/3/10 21:17:20

无电网电压传感器三相PWM整流器,采用虚拟磁链方法估算电网相位角度。 模型控制器部分全部采用离...

无电网电压传感器三相PWM整流器&#xff0c;采用虚拟磁链方法估算电网相位角度。 模型控制器部分全部采用离散化处理&#xff0c;设置成单采样单更新模式&#xff0c;SVPWM调制模式&#xff0c;开关频率固定&#xff0c;使用的是矢量控制技术。 该模型SVPWM模块全部由我独立重写…

作者头像 李华
网站建设 2026/3/5 15:08:51

视频真假难辨的时代真的来了!Sendance 2.0 3个使用渠道

字节发布了 Seedance 2.0&#xff0c;最新一代的视频生成模型&#xff0c;也是趁着年底搞事情。之前版本以及 Sora 等视频模型我也稍微玩儿过一些&#xff0c;作为一个纯外行来说&#xff0c;我觉得门槛还是挺高的。就是随便生成一段视频很简单&#xff0c;但是想要达到精良的水…

作者头像 李华
网站建设 2026/3/4 2:33:37

学术探险家的“智能罗盘”:书匠策AI解锁本科论文写作新宇宙

在学术的浩瀚星海中&#xff0c;本科论文写作常被比作“第一次独立航行”——既需要方向感&#xff0c;又需要工具箱。但传统写作模式下&#xff0c;选题撞车、文献迷航、逻辑断层、格式混乱等问题&#xff0c;让许多学生陷入“写论文像渡劫”的困境。如今&#xff0c;一款名为…

作者头像 李华