news 2026/6/15 15:31:36

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

人工智能应用- 人机对战:05. 深度神经网络

深度神经网络是AlphaGo 取得胜利的另一个关键因素。MTC 是一种走棋策略&#xff0c;但它本身并不具备记忆和学习能力。为此&#xff0c;AlphaGo 引入了深度学习方法&#xff0c;设计了两个卷积神经网络&#xff1a;策略网络和价值网络。策略网络用于评估每个 落 子 点 的 优 劣…

作者头像 李华
网站建设 2026/6/15 11:17:36

学术探险家指南:用书匠策AI解锁本科论文写作的“隐藏副本”

对于本科生而言&#xff0c;论文写作常被视为一场“学术闯关游戏”——选题撞车、文献迷宫、逻辑断层、格式陷阱……每一个关卡都可能让新手玩家陷入“熬夜爆肝却原地踏步”的循环。而如今&#xff0c;一款名为书匠策AI的科研工具&#xff0c;正以“游戏外挂”的姿态&#xff0…

作者头像 李华
网站建设 2026/6/15 11:23:11

【拯救HMI】工业HMI安全设计的深度审视:10个潜在风险点

工业HMI面临网络攻击和操作失误的双重威胁&#xff0c;2025年全球工业安全事件中&#xff0c;HMI相关占25%。本文从安全角度剖析10个风险点&#xff0c;每个结合事故案例&#xff0c;提供防护措施&#xff0c;帮助构建坚固的工业交互系统。风险点1&#xff1a;按钮设计模糊&…

作者头像 李华
网站建设 2026/6/15 11:22:17

张家埠潮汐表查询2026-02-12

位置&#xff1a;张家埠&#xff0c;日期&#xff1a;2026-02-12&#xff0c;农历&#xff1a;乙巳[蛇]年十二(腊)月廿五&#xff0c;星期&#xff1a;星期四&#xff0c;潮汐类型&#xff1a;小潮死汛 最高水位&#xff1a;266.00cm&#xff0c;最低水位&#xff1a;114.00cm&…

作者头像 李华