深入理解JVM(四) JVM参数以及命令

1. JVM参数

1.1 标准参数

-version
-help
-server
-cp  

1.2 -X参数

-Xint   解释执行
-Xcomp  第一次使用就编译成本地代码
-Xmixed  混合模式,JVM自己来决定

1.3  -XX参数

使用的最多的参数类型, 非标准化参数,相对不稳定,主要用于JVM调优和Debug

a.Boolean类型
格式:-XX:[+-]<name>      +或-表示启用或者禁用name属性
比如:-XX:+UseConcMarkSweepGC  表示启用CMS类型的垃圾回收器
-XX:+UseG1GC       表示启用G1类型的垃圾回收器
b.非Boolean类型
格式:-XX<name>=<value>表示name属性的值是value
比如:-XX:MaxGCPauseMillis=500

具体使用 参见1.7

1.4 其他参数

-Xms1000等价于-XX:InitialHeapSize=1000
-Xmx1000等价于-XX:MaxHeapSize=1000
-Xss100等价于-XX:ThreadStackSize=100

1.5 查看参数

 -XX:+PrintFlagsFinal

启动后打印以下信息

1.6 设置参数的方式

开发工具中设置比如IDEA,eclipse
运行jar包的时候:java -XX:+UseG1GC xxx.jar
web容器比如tomcat,可以在脚本中的进行设置
通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)

1.7 常用参数的含义,以及使用细则

参数 含义说明
XX:CICompilerCount=3最大并行编译数如果设置大于1,虽然编译速度会提高,但是同样影响系统稳定性,会增加JVM崩溃的可能
-XX:InitialHeapSize=100M 初始化堆大小简写-Xms100M
-XX:MaxHeapSize=100M最大堆大小简写-Xmx 100M
-XX:NewSize=20M设置年轻代的大小 
-XX:MaxNewSize=50年轻代最大大小 
-XX:OldSize=50M设置老年代大小 
-XX:MetaspaceSize=50M 设置方法区的大小 
-XX:MaxMetaspaceSize=50M 方法区最大大小 
-XX:+UseParallelGC 使用UseParallelGC新生代,吞吐量优先
-XX:+UseParallelOldGC使用UseParallelOldGC老年代,吞吐量优先
-XX:+UseConcMarkSweepGC使用CMS垃圾处理器老年代,停顿时间优先
-XX:+UseG1GC使用G1垃圾处理器新生代,老年代,停顿时间优先
-XX:NewRatio新老生代的比值比如-XX:Ratio=4,则表示新生代:老年代=1:4,也就是新生代占整个堆内存的1/5
-XX:SurvivorRatio 两个S区和Eden区的比值比如-XX:SurvivorRatio=8,也就是(S0+S1):Eden=2:8,也就是一个S占整个新生代的1/10
-XX:HeapDumpPath=heap.hprof  指定堆内存溢出打印目录表示在当前目录生成一个heap.hprof文件
-XX:+HeapDumpOnOutOfMemoryError 启动堆内存溢出打印当JVM堆内存发生溢出时,也就是OOM,自动生成dump文件
XX:+PrintGCTimeStamps -打印出Log日志可以使用不同的垃圾收集器,对比查看GC情况
XX:+PrintGCDateStamps
Xloggc:$CATALINA_HOME/logs/gc.log
-Xss128k  设置每个线程的堆栈大小经验值是3000-5000最佳
-XX:MaxTenuringThreshold=6 提升年老代的最大临界值默认值是15(代表标记15次进入老年代)
-XX:InitiatingHeapOccupancyPercent 启动并发GC周期时堆内存使用占比G1之类的垃圾收集器用它来触发并发GC周期,基于整个堆的使用率,而不只是某一代内存的使用比. 值为 0 则表示”一直执行GC循环”. 默认值为 45
-XX:G1HeapWastePercent 允许的浪费堆空间的占比默认是10%,如果并发标记可回收的空间小于10%,则不会触发MixedGC。
-XX:MaxGCPauseMillis=200ms G1最大停顿时间暂停时间不能太小,太小的话就会导致出现G1跟不上垃圾产生的速度。最终退化成Full GC。所以对这个参数的调优是一个持续的过程,逐步调整到最佳状态。
-XX:ConcGCThreads=n  并发垃圾收集器使用的线程数量默认值随JVM运行的平台不同而不同
-XX:G1MixedGCLiveThresholdPercent=65混合垃圾回收周期中要包括的旧区域设置,占用率阈值默认占用率为 65%
-XX:G1MixedGCCountTarget=8设置标记周期完成后,对存活数据上限为G1MixedGCLIveThresholdPercent 的旧区域执行混合垃圾回收的目标次数默认8次混合垃圾回收,混合回收的目标是要控制在此目标次数以内
XX:G1OldCSetRegionThresholdPercent=1描述Mixed GC时,Old Region被加入到CSet中默认情况下,G1只把10%的Old Region加入到CSet中

2. 常用命令

2.1 jps

查看java进程

2.2 jinfo

(1)实时查看和调整JVM配置参数

jinfo -flag name PID 查看某个java进程的name属性的值

 (2) 查询曾经赋值过的一些JVM参数

jinfo -flags PID

2.3 jstat

(1) 查看虚拟机性能统计信息

(2) 查看类装载信息

jstat -class PID 1000 10   查看某个java进程的类装载信息,每1000毫秒输出一次,共输出10次 

(3) 查看垃圾收集信息

 jstat -gc PID 1000 10

2.4 jstack

(1)查看线程堆栈信息

(2)用法

jstack PID

(3) 可以用来排查死锁, 阻塞线程

 

2.5 jmap 

(1) 生成堆存储快照

(2) 打印出堆相关信息

jmap -heap PID

(3) dump出堆相关的信息

jmap -dump:format=b,file=heap.hprof PID

(4) 要是在发生堆溢出的时候, 能自动dump出该文件就好了

一般在开发中,JVM参数可以加上下面两句,这样内存溢出时,会自动dump出该文件
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=heap.hprof

(5) 关于dump 下来的文件(用工具分析) 

 

对于JVM参数和命令就讲解到这里了, 关于如何用图形化页面来查看和如何分析dump文件,请参考我的下一篇文章

https://rourou.blog.csdn.net/article/details/103710972

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值