目录

第 1 层:Java 编程性能调优

第 2 层:多线程性能调优

第 3 层:JVM 性能监测及调优

第 4 层:设计模式调优

第 5 层:数据库性能调优


对于很多研发人员来说,Java 性能调优都是很头疼的问题。

比如,一个简单的系统就囊括了应用程序、数据库、容器、操作系统、网络等技术,线上一旦出现性能问题,就可能要你协调多方面组件去进行优化。另外,很多性能问题隐藏得很深,可能因为一个小小的代码,也可能因为线程池的类型选择错误......

看起来是挺错综复杂,但是也不是没有章法可循。这方面我深受金山软件西山居技术经理刘超的启发,他把 Java 性能调优分成 5 个层级:Java 编程、多线程、JVM 性能检测、设计模式、数据库性能,每个层级下都覆盖了最常见的优化问题。下面分别给你梳理一下:

第 1 层:Java 编程性能调优

JDK 是 Java 语言的基础库,熟悉 JDK 中各个包中的工具类,可以帮助你编写出高性能代码。课程从基础的数据类型讲起,涉及容器在实际应用场景中的调优,还有现在互联网系统架构中比较重要的网络通信调优。

第 2 层:多线程性能调优

目前大部分服务器都是多核处理器,多线程编程的应用广泛。为了保证线程的安全性,通常会用到同步锁,这会为系统埋下很多隐患;除此之外,还有多线程高并发带来的性能问题,这些都会在这个层级重点讲解。

第 3 层:JVM 性能监测及调优

Java 应用程序是运行在 JVM 之上的,对 JVM 进行调优可以提升系统性能。这个层级重点讲解 Java 对象的创建和回收、内存分配等。

第 4 层:设计模式调优

在架构设计中,我们经常会用到一些设计模式来优化架构设计。这里刘超会结合一些复杂的应用场景,分享设计优化案例。

第 5 层:数据库性能调优

数据库最容易成为整个系统的性能瓶颈,这里刘超会重点解析一些数据库的常用调优方法。

这些内容,都出自刘超的专栏《Java 性能调优实战》共 44 讲,最近刚 2 刷完毕,最大的收获是,对于 Java 性能优化,不仅要理解系统架构、应用代码,还需要关注 JVM 层甚至操作系统底层。有时候,深入理解 Java 底层源码就能达到事半功倍的效果。

从实战出发,精选高频性能问题,透过 Java 底层源码,提炼出优化思路和它背后的实现原理,最后形成一套“学完就能用的调优方法论”。这也是很多一线大厂对于高级工程师的要求。

把 Java 性能调优分成上文提到的 5 个层级:Java 编程、多线程、JVM 、设计模式、数据库,每个层级下都覆盖了最常见的性能问题。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐