JVM调优思路和步骤
JVM基本调优思路和步骤
我们经常会遇到程序平时运行还行,访问高峰期突然卡住的问题,或者程序突然OOM但是不知道从何查起。这个时候我们需要运用到JVM调优的一些思路来解决。
JVM常用调优工具
jdk有各种自带的命令可以用来调优,也可以使用一些调优工具来调优,这些调优工具都是对jdk自带的命令进行的一些封装,能够让显示结果更加直观,让我们使用起来更加的便捷。我们先了解一下最基础的jdk自带命令,之后使用任何调优工具也更简单。
JVM常用调优命令
pid指进程id,tid指线程id
jps: 显示当前所有java进程的进程id(pid)
jstat -gc pid:查看堆中各个区内存使用情况以及yong gc,full gc次数和时间
jmap -histo pid:查看指定进程的内存信息,实例个数以及占用内存大小
jmap -heap pid:查看jvm堆内存配置信息和堆内每个区总内存、已用内存、可用内存大小
jmap -dump:导出堆内存dump文件
jstack pid:查看线程信息
jstack pid|grep -A 10 tid:查看占用cpu最高的线程堆栈信息,此命令需要使用linux top指令查看进程下每个线程的cpu占用情况,windows没有相对应的命令
jinfo -flags pid:查看jvm的参数(配置后可以通过此命令确认参数是否生效)
调优工具Arthas
Arthas 是 Alibaba 在 2018 年 9 月开源的 Java 诊断工具。支持 JDK6+,支持Linux/Mac/Windows, 采用命令行交互模式,可以方便的定位和诊断线上程序运行问题。
Windows系统下载Arthas:
curl -O https://arthas.aliyun.com/arthas-boot.jar
linux系统
wget https://arthas.gitee.io/arthas-boot.jar
或
wget https://alibaba.g