码迷,mamicode.com
首页 > 其他好文 > 详细

JVM 常用参数

时间:2019-04-23 19:23:13      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:次数   serial   详细   内存   内存泄露   申请   print   示例   日志   

常见参数配置
  • -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 左右

-Xss5m 设置最大调用深度

内存溢出与内存泄漏区别

内存溢出:申请空间超出系统能够提供的空间大小

内存泄露:内存泄露是指程序中间动态分配了内存,但在程序结束时没有释放这部分内存,从而造成那部分内存不可用的情况,最终导致内存溢出

JVM 常用参数

标签:次数   serial   详细   内存   内存泄露   申请   print   示例   日志   

原文地址:https://blog.51cto.com/13559120/2383469

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!