最近遇到了不少内存方面的问题,抽了空了解了一下JAVA_OPTS。
什么是JAVA_OPTS
Java options的缩写,用来设置JVM相关运行参数的变量。
JVM:JAVA_OPTS="-server -Xrs -Xms1g -Xmx5g -Xss512k -XX:+UseParNewGC -Djava.awt.headless=true "
JAVA_OPTS参数简述
-server与-client参数
通过-server或-client设置jvm的运行参数
-server:初始堆空间会大一些,默认使用的是并行垃圾回收器,启动慢运行快
-client:初始堆空间会小一些,使用串行的垃圾回收器,它的目标是为了让JVM的启动速度更快,但运行速度会比-server慢些
根据操作系统的不同,使用不同的运行模式
运行模式 | 操作系统 |
---|---|
-server | 64位操作系统;机器配置有2GB以上的内存同时有2个以上CPU的32位非Windows操作系统 |
-client | 32位Windows操作系统 |
堆内存
-Xms:程序可用的最小Heap(堆)大小,cpu性能高时此值应设的大一些
-Xmx:程序可用的最大Heap(堆)大小
Xmx和Xms都是可选的。如果未提供这些,则Java虚拟机(JVM)将为其使用默认值。默认值取决于计算机和JVM配置。对于服务器类机器,这些定义为:
- 初始堆大小为物理内存的1/64
- 最大堆大小为物理内存的1/4
一般设置-Xms、-Xmx 相等以避免在每次垃圾回收(GC)后调整堆的大小
-Xss:设置每个线程的堆栈(Stack)大小
参数值使得每增加一个线程(thread)就会立即消耗对应的内存,最佳值是128K,默认值是512k
非堆内存
-XX:PermSize: 指非堆区初始化内存分配大小
-XX:MaxPermSize:指对非堆区分配内存的最大上限
注意:
配置之前,一定要慎重的考虑一下软件所需的非堆区内存的大小,
因为此处内存是不会被java垃圾回收机制进行处理的地方
垃圾回收
-verbose:gc 现实垃圾收集信息
-Xloggc:gc.log 指定垃圾收集日志文件
-XX:UseParallelGC:选择并行收集器。此配置仅对年轻代有效。可以同时并行多个垃圾收集线程,但此时用户线程必须停止。
-XX:UseParNewGC:设置年轻代为多线程收集。可与CMS收集同时使用。在serial基础上实现的多线程收集器。