JVM 备注

一、堆内存分布:
JAVA 分为堆内存和栈内存,GC主要针对堆内存
  1)Young: 存放新生内存对象
    1.1)Eden JVM 刚开始分配的对象
    1.2)Survivor1(from)
    1.3)Survivor2(to)两个区域一样大,Eden没有回收掉的对象会在两个区域来回拷贝,达到一定次数后移到Old。
    即该对象在Young中存留的时间。
  2)Old: 存放声明周期较长的内存对象
  3)Permanent:永久保存区,存放class和meta信息


二、垃圾回收的时机:
  1)当Eden代内存满时,会引发一次普通GC(Minor GC),该GC仅回收年轻代
  2)当年老代满时会引发Full GC,Full GC将会同时回收年轻代、年老代
  3)当永久代满时也会引发Full GC,会导致Class、Method元信息的卸载

  Full GC 消耗的时间较长,要尽量减少。

三、JVM 主要参数:
  -Xms<size> 设置JVM初始化堆内存大小
  -Xmx<size> 设置JVM最大的堆内存大小
  -Xss<size> 设置JVM栈内存大
  -Xmn<size> 设置JVM年轻代大小
  -XX:NewRatio 设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)
  -XX:SurvivorRatio= 设置年轻代中Eden区与Survivor区的大小比值
  -XX:MaxPermSize= 设置持久代大小

四、配置优化:

  参考:http://www.cnblogs.com/likehua/p/3369823.html

原文地址:https://www.cnblogs.com/Fredric-2013/p/5278731.html