jvm参数
- 标准参数:不随着jdk的版本变化而发生变化,
- 如java -version
- java -help
- -X 参数:随着jdk版本的变动而变动
- 如:-Xint(运行期解释字节码并执行)
- -XX参数
- Boolean类型
-XX:[+/-]name 启动或停止 - 非Boolean类型
- -XX:name = value
- -XX:MaxHeapSize=100M
- Boolean类型
- 其他参数[-XX参数]
- -Xms100M ===>等同于 -XX:InitialHeapSize=100M
- -Xmx100M ====> -XX:MaxHeapSize=100M
- -Xss100k ===> -XX:ThreadStackSize=100k
查看参数
- 查看所有: java -XX:+PrintFlagsFinal -version
*查看某个:jinfo
参数修改:
- idea、eclipse
- 运行jar包的时候:java -XX:+UseG1GC xxx.jar
- web容器比如tomcat,可以在脚本中的进行设置
- 通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)
实践和单位换算
1Byte(字节)=8bit(位) 1KB=1024Byte(字节)
1MB=1024KB 1GB=1024MB
1TB=1024GB
常用命令
- jps
- 查看java进程
- jinfo
- 实时查看和调整jvm配置参数
- 查看:jinfo -flag name PID(查看某个java进程的name属性的值)
- jinfo -flag MaxHeapSize PID
- jinfo -flag UseG1GC PID
- 修改:参数只有被标志为manageable的flags可以被实时修改
- jinfo -flag[+|-] PID
- jinfo -flag = PID
- 查看曾经赋值过的一些参数
- jinfo -flag PID
- jstat
- 查看虚拟机性能统计信息
- jstat -class PID 1000 10 查看某个java进程的类装载信息,每1000毫秒输出一次,共输出10 次
- 查看垃圾收集信息
- jstat -gc PID 1000 10
- jstack
- 查看进程堆栈信息
- 用法 jstack PID
- 排查死锁
- 死锁代码:
class MyLockObject{ public static Object object1 = new Object(); public static Object object2 = new Object(); } public class DealLockDemo { public static void main(String[] args) { new Thread(()->{ while (true){ synchronized (MyLockObject.object1){ System.out.println(Thread.currentThread().getName()+"获取到锁1"); synchronized (MyLockObject.object2){ System.out.println(Thread.currentThread().getName()+"获取锁2"); } } } }).start(); new Thread(()->{ while (true){ synchronized (MyLockObject.object2){ System.out.println(Thread.currentThread().getName()+"获取到锁2"); synchronized (MyLockObject.object1){ System.out.println(Thread.currentThread().getName()+"获取锁1"); } } } }).start(); } }
- 查看虚拟机性能统计信息
- jmap
- 生成堆转储快照
- 打印出堆内存相关信息
- jmap -heap PID
- dump出堆内存相关信息
- jmap -dump:format=b,file=heap.hprof 44808
- 在发生堆内存溢出的时候,自动dump出该文件
- -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=heap.hprof
常用工具
-
jconsole
-
jvisualvm
- 点击"线程" 如果有死锁,界面会提示“检测到死锁!”
- 工具–>插件–>VisualGC–>可以查看Metaspce,新生代,老年代等实时图形化信息。
- 监控远端Java进程(网上很多教程)
-
Arthas https://github.com/alibaba/arthas
-
Arthas 是Alibaba开源的Java诊断工具,采用命令行交互模式
-
Mat(相对比较强大的工具)
- 可以点击Overview–>Reports–>Leak Suspects(内存泄漏猜测)
-
在綫工具:
console.perfma.com
GC日志分析工具
- 打印GC日志:
-XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -Xloggc:gc.log
- 在线工具:
http://gceasy.io
- GCView
- 不断选择垃圾收集器,然后观测吞吐量和停顿时间的最佳值