天天看点

JVM 常用参数

常见参数配置

  • -XX:+PrintGC 每次触发GC的时候打印相关日志
  • -XX:+UseSerialGC 串行回收
  • -XX:+PrintGCDetails 更详细的GC日志
  • -Xms 堆初始值
  • -Xmx 堆最大可用值
  • -Xmn 新生代堆最大可用值
  • -XX:SurvivorRatio 用来设置新生代中eden空间和from/to空间的比例.
  • -XX:NewRatio 配置新生代与老年代占比 1:2
  • -XX:SurvivorRatio 用来设置新生代中eden空间和from/to空间的比例

总结:在实际工作中,我们可以直接将初始的堆大小与最大堆大小相等,这样的好处是可以减少程序运行时垃圾回收次数,从而提高效率

堆内存大小配置

使用示例: -Xmx20m -Xms5m

当前堆最大内存 20M,堆初始化内存 5M

设置新生代比例参数

使用示例:-Xms20m -Xmx20m -Xmn1m -XX:SurvivorRatio=2 -XX:+PrintGCDetails -XX:+UseSerialGC

当前堆最大内存 20M,初始化堆内存 20M,新生代最大可用内存 1M,Eden 区域和 form、to 区域的比例是 2:1:1,打印 GC 日志,使用串行回收

设置新生代与老年代比例参数

使用实例:-Xms20m -Xmx20m -XX:SurvivorRatio=2 -XX:NewRatio=2 -XX:+PrintGCDetails -XX:+UseSerialGC

当前堆最大内存 20M,初始化堆内存 20M,Eden 区域和 form、to 区域的比例是 2:1:1,新生代和老年代比例是 1:2,打印 GC 日志,使用串行回收

Java堆溢出

错误原因:java.lang.OutOfMemoryError: Java heap space 堆内存溢出

设置合适的堆大小:-Xms1m -Xmx100m -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError

最后的参数表示堆内存溢出出打印快照

虚拟机栈溢出

错误原因:java.lang.StackOverflowError 栈内存溢出

虚拟机栈溢出发生在递归调用,循环不会产生虚拟机栈溢出,除非循环里面嵌套递归

设置更大的深度,默认深度大概在 10000 左右

内存溢出与内存泄漏区别