天天看点

JVM堆内存划分和调优

JVM主要包括4个子系统:类加载器,运行时数据区,执行引擎,编译器。

JDK 1.8以前,分为新生代,老年代和永久代三个区域。1.8之后永久代换成了meta space元空间,主要是存放方法中的操作临时对象等,JDK1.8之前是占用JVM内存,JDK1.8之后直接使用物理内存。

其中新生代又分为Eden,S0,S1这三个部分。new出来的对象先分配到eden区,经过几次minor GC还存活的对象就会被放到S0区域,再经过几次minor GC还存活的对象会放到S1区。最后达到minor GC的阈值就放到老年代。老年代中就是major GC。Full GC 是Minor GC 加上 MajorGC。一般Full GC都会触发老年代和新生代的GC回收。

堆内存调优的关键:

实际上每一块子内存区中都会存在一部分可变伸缩区,如果空间不足,则在可变范围内扩大内存空间。

内存空间调整参数:

-Xms:设置初始分配大小,默认是物理内存的1/64

-Xmx:最大分配内存,默认是物理内存的1/4

-XX:+PrintGCDetails:输出详细的GC处理日志

-XX:+PrintGCDateStamps:输出GC的时间戳信息

-XX:+PrintHeapAtGC:在GC进行处理的前后打印堆内存信息。

-Xloggc:(SavePath):设置日志信息保存文件 在堆内存的调优策略中。

基本只要调整两个参数: -Xms -Xmx