常见的JVM参数
◼ 参数1 : -Xmx 和 –Xms-Xmx
参数设置的是最大堆内存,但是由于程序是运行在服务器或者容器上,计算可用内存时,要将元空间、操作系统、 其它软件占用的内存排除掉。
案例: 服务器内存4G,操作系统+元空间最大值+其它软件占用1.5G,-Xmx可以设置为2g。
最合理的设置方式应该是根据最大并发量估算服务器的配置,然后再根据服务器配置计算最大堆内存的值。 建议将-Xms设置的和-Xmx一样大,运行过程中不再产生扩容的开销。
◼ 参数2 : -XX:MaxMetaspaceSize 和 -Xss
-XX:MaxMetaspaceSize=值 参数指的是最大元空间大小,默认值比较大,如果出现元空间内存泄漏会让操作系 统可用内存不可控,建议根据测试情况设置最大值,一般设置为256m。
-Xss256k 栈内存大小,如果我们不指定栈的大小,JVM 将创建一个具有默认大小的栈。大小取决于操作系统和计 算机的体系结构。比如Linux x86 64位 : 1MB,如果不需要用到这么大的栈内存,完全可以将此值调小节省内存 空间,合理值为256k – 1m之间。
◼ 参数3:
-Xmn 年轻代的大小,默认值为整个堆的1/3,可以根据峰值流量计算最大的年轻代大小,尽量让对象只存放在年 轻代,不进入老年代。但是实际的场景中,接口的响应时间、创建对象的大小、程序内部还会有一些定时任务等不 确定因素都会导致这个值的大小并不能仅凭计算得出,如果设置该值要进行大量的测试。G1垃圾回收器尽量不要设 置该值,G1会动态调整年轻代的大小。
◆ 打印GC日志 JDK8及之前 :
-XX:+PrintGCDetails-XX:+PrintGCDateStamps-Xloggc:文件路径
JDK9及之后 :
-Xlog:gc*:file=文件路径
◆ -XX:+DisableExplicitGC
禁止在代码中使用System.gc(), System.gc()可能会引起FULLGC,在代码中尽量不要使用。
使用 DisableExplicitGC参数可以禁止使用System.gc()方法调用。
◆-XX:+HeapDumpOnOutOfMemoryError:
发生OutOfMemoryError错误时,自动生成hprof内存快照文件。-XX:HeapDumpPath=:指定hprof文件的输出路径。
JVM参数模板:
注意: JDK9及之后gc日志输出修改为 -Xlog:gc*:file=文件名 堆内存大小和栈内存大小根据实际情况灵活调整。