Java中怎么监控一个应用的性能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
JVM的参数类型
标准参数(Eg.)
-help
-server/-client
-version/-showversion
-cp/-classpath
X参数(非标准化参数)
-Xint: 解释执行
-Xcomp: 第一次使用就编译成本地代码
-Xmixed: 混合模式,jvm自己来决定是否编译成本地代码
XX参数(非标转化参数,相对不稳定,主要用于JVM调优和Debug)
-Xmx/-Xms
(实际上是XX参数) 设置JVM的最大内存和最小内存,-Xms等价于-XX:InitialHeapSize
,-Xmx等价于-XX:MaxHeapSize
-XX:+PrintFlagsInitial
查看JVM运行参数的初始值
-XX:+PrintFlagsFinal
查看JVM运行参数的最终值(=表示默认值,:=表示被用户或者JVM修改后的值)
-XX:+UnlockExperimentalVMOptions
解锁实验参数
-XX:+UnlockDiagnosticVMOptions
解锁诊断参数
-XX:+PrintCommandLineFlags
打印命令行参数
-XX:+HeapDumpOnOutOfMemoryError
当发生内存溢出了,自动Dump Heap Error
-XX:HeapDumpPath=./
内存溢出HeapDump的日志,./
指的是当前运行目录
Boolean类型: -XX:[+|-]<name>
,例如: -XX:+UseConcMarkSweepGC
非Boolean类型: -XX:<name>=<value>
表示name属性的值是value,例如:-XX:MaxGCPauseMillies=500
jps
jps默认能够看到所有的java进程
-l
参数表示看到具体的Class
!!!需要补全所有的参数
jinfo
jstat
Loaded
类加载的个数
Bytes
类加载了多少个kBs
Unloaded
类卸载的个数
Bytes
类卸载了多少个kBs
Time
类加载和卸载总共花费的时间
-class
查看类装载信息,用法 jstat -class [pid] [interval millseconds] [count]
代表间隔interval毫秒时间打印count次的pid的类装载信息:
-compiler
查看JIT编译的信息,jstat -compiler [pid] [interval millseconds] [count]
代表间隔interval毫秒时间打印count次的pid的JIT编译信息信息:
-gc
查看垃圾收集的信息,用法 jstat -gc [pid] [interval millseconds] [count]
代表间隔interval毫秒时间打印count次的pid的gc信息:
-gcutil
-gccause
-gcnew
-gcold
-printcompilation
!!!需要补全所有参数
类装载信息
垃圾收集信息
JIT编译信息
JVM的内存结构
堆区:Young区(Servival区[S0+S1]+Eden区) + Old区,S0和S1是一样大的,在同一时间,S0和S1只会启用一个
非堆区(Metaspace):操作系统的本地内存,CCS区(启用了短指针之后则存在)+CodeCache区(存放的是JIT的代码信息,JNI的代码信息也在这)
如何定位内存溢出的问题
构造一个内存溢出,例如设置下-Xmx32M -Xms32M
,构造一个堆内存溢出,只需要一直不停的new对象;设置-XX:MetaspaceSize=32M -XX:MaxMetaspaceSize=32M
下构造出一个非堆内存溢出,例如使用ASM不太的构造Class文件。
内存溢出的区别
jmap
可以手动导出Heap日志
看完上述内容,你们掌握Java中怎么监控一个应用的性能的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注天达云行业资讯频道,感谢各位的阅读!