转自:
http://www.java265.com/JavaCourse/202204/2648.html
下文笔者讲述java中JVM参数的简介说明,如下所示:
JVM参数类型说明
- 常见的JVM参数类型如下:
- 1.标准的jvm参数 -version -help
- 2.X非标准参数, -Xms -Xmx
- 3.XX不稳定参数, -XX:+PrintGC 设置这些参数会引起JVM性能差异
- 可能导致JVM性能提升,也可导致JVM异常而停止服务
- 注意事项:
- -X和-XX参数可能随着JDK版本的变更而发生变化
- 在下一个版本中有些参数可以能会被废弃掉,
- 有些参数的功能会发生改变
- 但JDK官方不会通知开发者这些变化,需要使用者注意
复制代码 XX参数数值类型
- 1.布尔类型 ,
- 如-XX:+PrintGCDetails
- 其中+和-
- +代表开启功能
- -代表关闭功能
- 2.KV 属性设置
- 如-XX:NewSize=512M
- 设置年轻代空间大小为512M
-
复制代码 常用参数
参数 | 功能 | 默认值 | 示例 | 备注 | -Xms | 初始堆大小 | 物理内存64分之一 | -Xms=512M | | -Xmx | 最大堆大小 | 物理内存4分之一 | -Xmx=512M | 笔者建议同-Xms设置同样的值 | -Xmn | 新生代大小 | | -Xmn=512M | 尽量设置小一点 | -Xss | 指定线程栈大小 | | -Xss=512M | webx下需要设置256K | X其它参数-打印GC信息到文件
-Xloggc:/log/gc_%t_%p.log:将gc信息打印到指定的文件中,通过时间戳生成文件名
XX参数
- -XX:NewSize:设置年轻代最小空间大小
- -XX:MaxNewSize:设置年轻代最大空间大小
- -XX:PermSize:设置永久代最小空间大小
- -XX:MaxPermSize:设置永久代最大空间大小
- -XX:NewRatio:设置年轻代和老年代的比值。默认值-XX:NewRatio=2,表示年轻代与老年代比值为1:2,年轻代占整个堆大小的1/3
- -XX:SurvivorRatio:设置年轻代中Eden区Survivor区的容量比值。默认值-XX:SurvivorRatio=8,表示Eden : Survivor0 : Survivor1 = 8 : 1 : 1
- -XX:-OmitStackTraceInFastThrow:关闭(省略异常栈从而快速抛出),默认开启。如果想将所有异常信息都抛出,建议关闭。
- -XX:+HeapDumpOnOutOfMemoryError:表示当JVM发生OOM时,自动生成DUMP文件。
- -XX:HeapDumpPath=/usr/local/dump:dump文件路径或者名称。如果不指定文件名,默认为:java_<pid>_<date>_<time>_heapDump.hprof
-
复制代码 GC日志
在设置JVM参数的时候
可以设置GC打印日志参数
-XX:+PrintGCDetails- 日志列简介说明
- GC:表示进行了一次Minor GC,即从年轻代空间(包括 Eden 和 Survivor 区域)回收内存
- Allocation Failure:在年轻代中没有足够的空间能够存储新的数据
- Full GC (Ergonomics):表示进行了一次Full GC,即清理整个堆空间(包含年轻代和老年代)
- PSYoungGen: 1024K->1024K(1488K):垃圾回收器是Paralle Scavenge,年轻代区GC前->GC后该区域已使用量,后面的1488表示该区域总量
- ParOldGen: 4011K->4011K(4082K)老年代区,GC前->GC后该区域已使用量,后面的4082表示该区域总量
- 5032K->5032K(5899K):GC前 -> GC后Java堆的使用量,后面的5899表示Java堆总量
- Metaspace: 3117K->3117K(1056768K):JDK8中取消了永久代,新增了一个叫元空间(Metaspace)的区域,对应的还是JVM规范中的方法区(主要存放一些class和元数据的信息),该数据表示该区GC前后使用量
- 0.0118131 secs:暂停STW 时间,即GC的时间
- Times: user=0.01 sys=0.01, real=0.01 secs:更为详细的时间占比统计
复制代码 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |