前言
Java世界的知识浩如烟海,年轻的我们在学习和遗忘的一次次轮回中掉光了头发
所谓好记性不如烂笔头,笔者将一些字典类的知识进行整理,与君共赏
常用jvm参数
参数 | 说明 |
---|---|
-Xms | -X memory size:初始堆大小, 默认为物理内存的1/64(<1GB);默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制 |
-Xmx | -X memory max:最大堆大小, 默认(MaxHeapFreeRatio参数可以调整)空余堆内存大于70%时,JVM会减少堆直到 -Xms的最小限制 |
-Xmn | -X memory new:新生代的内存空间大小, 注意:此处的大小是(eden+ 2 survivor space)。与jmap -heap中显示的New gen是不同的。整个堆大小=新生代大小 + 老生代大小 + 永久代大小。在保证堆大小不变的情况下,增大新生代后,将会减小老生代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8 |
-Xss | -X stack size:每个线程的堆栈大小, JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。应根据应用的线程所需内存大小进行适当调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。一般小的应用, 如果栈不是很深, 应该是128k够用的,大的应用建议使用256k。这个选项对性能影响比较大,需要严格的测试。和threadstacksize选项解释很类似,官方文档似乎没有解释,在论坛中有这样一句话:"-Xss is translated in a VM flag named ThreadStackSize”一般设置这个值就可以了 |
JVM常用的命令
jsp命令(虚拟机进程状况工具)
命令:
jps [ options ] [ hostid ]
参数:
参数 | 说明 |
---|---|
-q | 只输出LVMID,省略主类的名称 |
-m | 输出虚拟机进程启动时传递给主类main函数的参数 |
-l | 输出主类的全名,如果进程执行的是jar包, 则输出jar路径 |
-v | 输出虚拟机进程启动时的JVM参数 |
示例:
JRMD3GB7MD6M ~ % jps
89665 Jps
1731
36934
14550
JRMD3GB7MD6M ~ % jps -v
89682 Jps -Dapplication.home=/Library/Java/JavaVirtualMachines/jdk-11.0.13.jdk/Contents/Home -Xms8m -Djdk.module.main=jdk.jcmd
1731 -Dfile.encoding=UTF-8 -XstartOnFirstThread
36934 -Xms128m -Xmx750m -XX:ReservedCodeCacheSize=512m -XX:+IgnoreUnrecognizedVMOptions -XX:+UseG1GC -XX:SoftRefLRUPolicyMSPerMB=50 -XX:CICompilerCount=2 -XX:+HeapDumpOnOutOfMemoryError -XX:-OmitStackTraceInFastThrow -ea -Dsun.io.useCanonCaches=false -Djdk.http.auth.tunneling.disabledSchemes="" -Djdk.attach.allowAttachSelf=true -Djdk.module.illegalAccess.silent=true -Dkotlinx.coroutines.debug=off -XX:ErrorFile=/Users/xidi/java_error_in_idea_%p.log -XX:HeapDumpPath=/Users/xidi/java_error_in_idea.hprof -Dide.no.platform.update=true -Dtoolbox.notification.token=W4CI0eMVt21cCzPBklYM2w3ET2YMQdNrIcmhFbNfzd8= -Dtoolbox.notification.portFile=/Users/xidi/Library/Application Support/JetBrains/Toolbox/apps/IDEA-C/ch-1/221.5921.22/IntelliJ IDEA CE.app.vmoptions.port -Didea.plugins.path=/Users/xidi/Library/Application Support/JetBrains/Toolbox/apps/IDEA-C/ch-1/221.5921.22/IntelliJ IDEA CE.app.plugins -Xmx2048m -Djb.vmOptionsFile=/Users/xidi/Library/Application Support/JetBrains/Toolbox/ap
jstat(虚拟机统计信息监视工具)
命令:
jstat [ option vmid [interval[s|ms] [count]] ]
参数:
参数 | 说明 |
---|---|
-class | 监视类加载、卸载数量、总空间以及类转改所耗费的时间 |
-gc | 监视Java堆状况,包括Eden区、2个Survivor区、老年代、永久代等的容量,已用空间,垃圾收集时间合计等信息 |
-gccapacity | 监视内容与-gc基本相同,但输出主要关注Java堆各个区域使用到的最大、最小空间 |
-gcutil | 监视内容与-gc基本相同,但输出主要关注已使用空间占总空间的百分比 |
-gccause | 与-gcutil功能一样,但是会额外输出导致上一次垃圾收集产生的原因 |
-gcnew | 监视新生代垃圾收集状况 |
-gcnewcapacity | 监视内容与-gcnew基本相同,输出主要关注使用到的最大、最小空间 |
-gcold | 监视老年代垃圾收集状况 |
-gcoldcapacity | 监视内容与-gcold基本相同, 输出主要关注使用到的最大、最小空间 |
-gcpermcapacity | 输出永久代使用到的最大、最小空间 |
-compiler | 输出即时编译器编译过的方法、耗时等信息 |
-printcompilation | 输出已经被及时编译的方法 |
示例:
JRMD3GB7MD6M ~ % jstat -gcutil 36934 1000 10
S0 S1 E O M CCS YGC YGCT FGC FGCT CGC CGCT GCT
0.00 100.00 85.30 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.30 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.30 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.30 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.30 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.44 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.44 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.44 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.44 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
0.00 100.00 85.44 98.96 96.24 89.26 1362 24.232 17 22.106 786 25.907 72.245
JRMD3GB7MD6M ~ % jstat -compiler 36934
Compiled Failed Invalid Time FailedType FailedMethod
155406 4 0 1048.01 1 com/jetbrains/packagesearch/intellij/plugin/data/InstalledPackagesUtilsKt installedPackages
jinfo(Java配置信息工具)
命令
jinfo [ option ] pid
参数:
参数 | 说明 |
---|---|
-flag | 打印命名VM标志的值 |
-flags | 打印VM标志 |
-flag [+|-] | 启用或禁用命名VM标志 |
-flag = | 将命名VM标志设置为给定值 |
-sysprops | 打印Java系统属性 |
打印以上两项 |
示例:
JRMD3GB7MD6M ~ % jinfo -flag CMSInitiatingOccupancyFraction 36934
-XX:CMSInitiatingOccupancyFraction=-1
JRMD3GB7MD6M ~ % jinfo -sysprops 36934
Java System Properties:
#Thu Sep 22 11:00:21 CST 2022
awt.toolkit=sun.lwawt.macosx.LWCToolkit
java.specification.version=11
kotlinx.coroutines.debug=off
sun.cpu.isalist=
sun.jnu.encoding=UTF-8
sun.arch.data.model=64
idea.fatal.error.notification=disabled
sun.font.fontmanager=sun.font.CFontManager
pty4j.preferred.native.folder=/Users/xidi/Library/Application Support/JetBrains/Toolbox/apps/IDEA-C/ch-1/221.5921.22/IntelliJ IDEA CE.app/Contents/lib/pty4j-native
java.vendor.url=https\://openjdk.java.net/
idea.plugins.path=/Users/xidi/Library/Application Support/JetBrains/Toolbox/apps/IDEA-C/ch-1/221.5921.22/IntelliJ IDEA CE.app.plugins
apple.awt.fileDialogForDirectories=true
sun.java2d.uiScale.enabled=true
sun.io.useCanonCaches=false
...
jmap(Java内存映像工具)
命令:
jmap [ option ] vmid
参数:
参数 | 说明 |
---|---|
-dump | 生成Java堆转储快照。格式为-dump:[live,]format=b,file=,其中live子参数说明是否只dump出存活的对象 |
-finalizerinfo | 显示在F-Queue中等待Finalizer线程执行finalize方法的对象。只在Linux/Solaris平台下有效 |
-heap | 显示Java堆详细信息,如使用哪种回收器、参数配置、分代状况等。只在Linux/Solaris平台下有效 |
-histo | 显示堆中对象统计信息,包括类,实例数量、合计容量 |
-permstat | 以ClassLoader为统计口径显示永久代内存状态。只在Linux/Solaris平台下有效 |
-F | 当虚拟机进程对-dump选项没有响应时,可使用这个选项强制生成dump快照。只Linux/Solaris平台下有效 |
示例:
JRMD3GB7MD6M ~ % jmap -dump:format=b,file=test.bin 1731
Heap dump file created
jhat(虚拟机堆转储快照分析工具)
命令:
jhat [-stack ] [-refs ] [-port ] [-baseline ] [-debug ] [-version] [-h|-help]
参数:
参数 | 说明 |
---|---|
-J | 将直接传递给运行时系统。例如,-J-mx512m使用最大堆大小512MB |
-stack false: | 关闭跟踪对象分配调用堆栈 |
-refs false: | 关闭对对象的引用的跟踪 |
-port : | 设置HTTP服务器的端口。默认为7000 |
-exclude : | 指定一个文件,该文件列出应从reachableFrom查询中排除的数据成员 |
-baseline : | 指定基线对象转储。两个堆转储中具有相同ID和相同类的对象将被标记为非“新” |
-debug : | 设置调试级别。0:无调试输出1:调试hprof文件解析2:调试hpprof文件解析,无服务器 |
-version | 报告版本号 |
要读取的文件 |
示例:
解析完成,显示“Server is ready.”后,用户在浏览器中输入http://localhost:7000/可以看到分析结果
析结果默认以包为单位进行分组显示,分析内存泄漏问题主要会使用到其中的“HeapHistogram”(与jmap-histo功能一样)与OQL页签的功能,前者可以找到内存中总容量最大的对象,后者是标准的对象查询语言,使用类似SQL的语法对内存中的对象进行查询统计。
JRMD3GB7MD6M ~ % jhat test.bin
Reading from test.bin...
Dump file created Thu Sep 22 15:27:04 CST 2022
Snapshot read, resolving...
Resolving 4441575 objects...
Chasing references, expect 888 dots...........................................................................................................................................................
Eliminating duplicate references......................................................................................................................................................
Snapshot resolved.
Started HTTP server on port 7000
Server is ready.
jstack(Java堆栈跟踪工具)
命令:
jstack [ option ] vmid
参数:
选 项 | 作 用 |
---|---|
-F | 当正常输出的请求不被响应时,强制输出线程堆栈 |
-l | 除堆栈外,显示关于锁的附加信息 |
-m | 如果调用到本地方法的话,可以显示C/C++的堆栈 |
示例:
JRMD3GB7MD6M ~ % jstack -l 1731
2022-09-22 15:32:59
Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.152-b16 mixed mode):
"Attach Listener" #3137 daemon prio=9 os_prio=31 tid=0x0000000101b5b000 nid=0x26337 waiting on condition [0x0000000000000000]
java.lang.Thread.State: RUNNABLE
Locked ownable synchronizers:
- None
"Worker-61" #2925 prio=5 os_prio=31 tid=0x0000000101e73000 nid=0x1742f in Object.wait() [0x0000700006cee000]
java.lang.Thread.State: TIMED_WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
at org.eclipse.core.internal.jobs.WorkerPool.sleep(WorkerPool.java:188)
- locked <0x00000006c0a956b8> (a org.eclipse.core.internal.jobs.WorkerPool)
at org.eclipse.core.internal.jobs.WorkerPool.startJob(WorkerPool.java:220)
at org.eclipse.core.internal.jobs.Worker.run(Worker.java:52)
Locked ownable synchronizers:
- None
...
"GC task thread#8 (ParallelGC)" os_prio=31 tid=0x0000000101010000 nid=0x6003 runnable
"GC task thread#9 (ParallelGC)" os_prio=31 tid=0x000000010080c800 nid=0x9d03 runnable
"VM Periodic Task Thread" os_prio=31 tid=0x0000000103871800 nid=0x6d03 waiting on condition
JNI global references: 3153