当前位置: 首页 > news >正文

后端接口性能优化分析

  • 👏作者简介:大家好,我是爱吃芝士的土豆倪,24届校招生Java选手,很高兴认识大家
  • 📕系列专栏:Spring源码、JUC源码
  • 🔥如果感觉博主的文章还不错的话,请👍三连支持👍一下博主哦
  • 🍂博主正在努力完成2023计划中:源码溯源,一探究竟
  • 📝联系方式:nhs19990716,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬👀

文章目录

    • 定位问题&问题排查
    • 常见思路
    • 实际问题解决(复杂优化问题)
  • 文献参考

事实上,当决定进行这个后端接口分析专栏部分的时候,我是低估了工作量的,因为以我当时的认知,并没有这么多的内容,随着不断地发现新的知识点,不断地调研,不断地总结,最终,一个适合我目前经验的后端接口优化篇幅就完成了。总的来说,当完成了这部分的时候,我总体上对知识有了一个更加全面的了解,将很多的知识融汇贯通了起来,形成了一个体系,这也是我最大的收获!

下面主要以三个思路来介绍,分别是 定位问题&问题排查、常见思路、实际问题解决

定位问题&问题排查

该部分主要介绍如何定位问题,出现问题如何排查的思路,这也是如何发现待优化点的思路。

后端接口性能优化分析-问题发现&问题定义-CSDN博客

常见思路

以15个常见的优化点来展开概括的介绍对应优化点

1.批量思想:

2.异步思想:

3.多线程思想:

4.空间换时间思想:恰当使用缓存

5.预取思想:提前初始化到缓存

6.池化思想:预分配与循环使用

7.事件回调思想:拒绝阻塞等待

8.锁粒度避免过粗

9.切换存储方式:文件中转暂存数据

10.优化程序结构

11.压缩传输内容

12.线程池设计

13.机器问题 (GC、线程打满、太多IO资源没关闭等等)

14.调用链路的优化

15.数据库优化

后端接口性能优化分析-多线程优化-CSDN博客

后端接口性能优化分析-程序结构优化-CSDN博客

后端接口性能优化分析-数据库优化-CSDN博客

实际问题解决(复杂优化问题)

实际问题的优化,是根据真实发生的问题而做的优化,这部分内容主要是参考优秀的技术博客。

也希望大家能够在理解优化的常见思路后能够结合 真实优化问题做到将优化思路融会贯通!

查询接口性能优化实录,讲点新手也能用的 - 掘金 (juejin.cn)

接口优化🚀68474ms->1329ms - 掘金 (juejin.cn)

只改了五行代码接口吞吐量提升了10多倍 - 掘金 (juejin.cn)

接口流量突增,如何做好性能优化? - 掘金 (juejin.cn)

评分接口性能优化 10 倍 - 掘金 (juejin.cn)

文献参考

[1] 细数线程池的10个坑 (qq.com)

[2] 实战总结!18种接口优化方案的总结 (qq.com)

[3] 看看别人后端API接口性能优化的11个方法,那叫一个优雅! - 掘金 (juejin.cn)

[4] Java后端服务接口性能优化建议 - 掘金 (juejin.cn)

[5] 慢接口优化思路 - 掘金 (juejin.cn)

[6] 聊聊接口优化的几个方法 - 掘金 (juejin.cn)

[7] 浅谈系统性能提升的经验和方法 (qq.com)

[8] Java接口全链路优化:如何降低接口RT时长 - 掘金 (juejin.cn)

[9] Java线上问题排查系列–后端接口响应慢的排查方法及解决方案_java接口慢排查_IT利刃出鞘的博客-CSDN博客

[10] 架构必知:后端服务实战之性能优化_ITFLY8的博客-CSDN博客

[11] 两万字的性能优化指南!39个策略提升接口性能! - 掘金 (juejin.cn)

[12] 看一遍就理解:group by 详解 - 知乎 (zhihu.com)

[13] (二十二)全解MySQL之分库分表后带来的“副作用”一站式解决方案! - 掘金 (juejin.cn)

[14] 分布式事务之可靠消息最终一致性、最大努力通知 - 知乎 (zhihu.com)

[15] explain | 索引优化的这把绝世好剑,你真的会用吗? - 掘金 (juejin.cn)

[16] 慢SQL原因分析之索引失效 | 京东物流技术团队 - 掘金 (juejin.cn)

[17] MySQL高级篇——索引失效的11种情况_mysql索引失效的几种情况-CSDN博客

[18] 还不会使用分布式锁?教你三种分布式锁实现的方式 - 掘金 (juejin.cn)

[19] 聊聊redis分布式锁的8大坑 - 掘金 (juejin.cn)

[20] 一文搞懂 Redis 高性能之 IO 多路复用 - 掘金 (juejin.cn)

[21] 聊聊并发编程的12种业务场景 - 掘金 (juejin.cn)

[22] 异步编程利器:CompletableFuture详解 |Java 开发实战 - 掘金 (juejin.cn)

[23] 从消息队列常见问题入手探讨消息队列 - 掘金 (juejin.cn)

[24] 统一观测丨如何使用Prometheus 实现性能压测指标可观测 - 掘金 (juejin.cn)

[25] Java后端接口响应慢的排查方法及解决方案 - 自学精灵 (skyofit.com)

[26] Java-系统问题排查的方法 - 自学精灵 (skyofit.com)

http://www.lryc.cn/news/231764.html

相关文章:

  • 【ceph】ceph集群中使用多路径(Multipath)方法
  • Xshell+Xftp通过代理的方式访问局域网内网服务器
  • 对盒子中的材料进行计数
  • 科技驱动固定资产管理变革:RFID技术的前沿应用
  • Django路由层之有名分组和无名分组、反向解析、路由分发、伪静态的概念、名称空间、虚拟环境、Django1和Django2的区别
  • 【nlp】2.5 人名分类器实战项目(对比RNN、LSTM、GRU模型)
  • 海康Visionmaster-环境配置:MFC 二次开发环境配置方法
  • 利用EXCEL中的VBA对同一文件夹下的多个数据文件进行特定提取
  • FPGA时序约束(七)文献时序约束实验测试
  • 【数据库开发】DataX开发环境的安装部署(Python、Java)
  • Flutter实践一:package组织
  • SpringCloud微服务:Ribbon负载均衡
  • 【教程】大气化学在线耦合模式WRF/Chem
  • GDS 命令的使用 srvctl service TAF application continuity
  • go 语言之 select
  • 23款奔驰GLC260L升级小柏林音响 全新15个扬声器
  • ssh 免密码登录
  • 小程序使用腾讯位置插件获取当前位置
  • 零基础学Python怎么学习?我来告诉你
  • 开源软件 FFmpeg 生成模型使用图片数据集
  • Linux Shell 通配符 / glob 模式
  • 深入了解域名与SSL证书的关系
  • 计算属性与watch的区别,fetch与axios在vue中的异步请求,单文本组件使用,使用vite创建vue项目,组件的使用方法
  • 2023.11.14 hivesql的容器,数组与映射
  • Android Glide照片宫格RecyclerView,点击SharedElement共享元素动画查看大图,Kotlin(1)
  • SELinux零知识学习八、SELinux策略语言之客体类别和许可(2)
  • deepstream-测试发送AMQP
  • LLMs可以遵循简单的规则吗?
  • 如何挑选护眼灯?光照均匀度、色温、眩光这3点!
  • python 实验7