JVM区域总体分两类,heap区和非heap区。
heap区又分为:
- Eden Space(伊甸园)
- Survivor Space(幸存者区)
- Old Gen(老年代)
非heap区又分:
- Code Cache(代码缓存区)
- Perm Gen(永久代)
- Jvm Stack(java虚拟机栈)
- Local Method Statck(本地方法栈)
下面我们对每一个内存区域做详细介绍。
Eden Space字面意思是伊甸园,对象被创建的时候首先放到这个区域,进行垃圾回收后,不能被回收的对象被放入到空的survivor区域。
Survivor Space幸存者区,用于保存在eden space内存区域中经过垃圾回收后没有被回收的对象。Survivor有两个,分别为To Survivor、 From Survivor,这个两个区域的空间大小是一样的。执行垃圾回收的时候Eden区域不能被回收的对象被放入到空的survivor(也就是To Survivor,同时Eden区域的内存会在垃圾回收的过程中全部释放),另一个survivor(即From Survivor)里不能被回收的对象也会被放入这个survivor(即To Survivor),然后To Survivor 和 From Survivor的标记会互换,始终保证一个survivor是空的。
Eden Space和Survivor Space都属于新生代,新生代中执行的垃圾回收被称之为Minor GC(因为是对新生代进行垃圾回收,所以又被称为Young GC),每一次Young GC后留下来的对象age加1。
注:GC为Garbage Collection,垃圾回收。
Old Gen老年代,用于存放新生代中经过多次垃圾回收仍然存活的对象,也有可能是新生代分配不了内存的大对象会直接进入老年代。经过多次垃圾回收都没有被回收的对象,这些对象的年代已经足够old了,就会放入到老年代。
当老年代被放满的之后,虚拟机会进行垃圾回收,称之为Major GC。由于Major GC除并发GC外均需对整个堆进行扫描和回收,因此又称为Full GC。
heap区即堆内存,整个堆大小=年轻代大小 + 老年代大小。堆内存默认为物理内存的1/64(<1GB);默认空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制,可以通过MinHeapFreeRatio参数进行调整;默认空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制,可以通过MaxHeapFreeRatio参数进行调整。
Jvm性能出现问题的常见原因为:年轻代垃圾回收机制设置不合适,导致survivor区域和edon区域被装满,而且只有edon区域被装满会触发young gc,young gc时将edon区域的对象放入survivor区域,如果这时suivivor区域满了,系统就会触发full gc,就会出现响应延迟。Web应用对于响应要求较高,因此通常设置较大的年轻代,采用并行收集的方法,老年代采用并发收集的方法,反复测试,一般的目标结果是要在edon和survivor区域还未满时就触发gc,保证年轻代始终有空余空间。
附常用配置参考:
-server
-Xms8192M 堆最小值
-Xmx8192M 堆最大值
-Xmn2048M 年轻代大小
-Xss512k 每个线程堆栈大小
-XX:PermSize=500M 持久代大小
-XX:MaxPermSize=500M 持久代最大值
-XX:+DisableExplicitGC
-XX:SurvivorRatio=2 年轻代中Edon区与suivivor区的比值(from:to:suivivor=1:1:2)
-XX:+UseConcMarkSweepGC 老年代并发收集,适合响应要求高的应用
-XX:+UseParNewGC 年轻代并行收集
-XX:+UseCMSCompactAtFullCollection 打开对老年代的压缩
-XX:CMSFullGCsBeforeCompaction=0运行多少次GC后对内存空间进行压缩、整理
-XX:+CMSClassUnloadingEnabled
-XX:LargePageSizeInBytes=128M
-XX:+UseFastAccessorMethods
-XX:+UseCMSInitiatingOccupancyOnly
-XX:CMSInitiatingOccupancyFraction=75
-XX:SoftRefLRUPolicyMSPerMB=0
-XX:+AggressiveOpts
-XX:+UseBiasedLocking
-Djava.awt.headless=true
-XX:+PrintClassHistogram
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-XX:+PrintGCDateStamps
-XX:+PrintHeapAtGC
-Xloggc:F:/tomcat8085/logs/gc.log
Jvm的内存区域详解:https://blog.youkuaiyun.com/shiyong1949/article/details/52585256
Jvm调优过程:https://www.cnblogs.com/andy-zhou/p/5327288.html