介绍
jvm调优就是根据gc日志分析jvm内存分配、回收的情况来调整各区域内存比例或者gc回收的策略;更深一层就是根据dump出来的内存结构和线程栈来分析代码中不合理的地方给予改进。
堆内存的分布
java7
Java8
Java8以后将永久区更换为元空间,其他都是一样的
参数详解:
-Xms:初始内存大小
-Xmx:最大内存大小
调优
参数:-Xms:设置初始分配大小,默认为物理内存的1/64
-Xmx:最大分配内存,默认为物理内存的1/4
-XX:+PrintGCDetails:输出详细的GC处理日志
代码详解:
public static void main(String[] args){ long maxMemory = Runtime.getRuntime().maxMemory() ;//返回 Java 虚拟机试图使用的最大内存量,最大值 long totalMemory = Runtime.getRuntime().totalMemory() ;//返回 Java 虚拟机中的内存总量,初始值 System.out.println("MAX_MEMORY = " + maxMemory + "(字节)、" + (maxMemory / (double)1024 / 1024) + "MB"); System.out.println("TOTAL_MEMORY = " + totalMemory + (" 字节)、 " + (totalMemory / (double)1024 / 1024) + "MB"); }
调整内存大小
默认的情况下分配的内存是总内存的“1 / 4”、而初始化的内存为“1 / 64”
参数调整:-Xms1024m -Xmx1024m -XX:+PrintGCDetails(将最大内存和初始内存调为一样,1G)
运行结果:
分配的内存=新生区+老年区(堆物理上分为两个区域,新生区和老年区)
制造OOM
将最大内存和最小内存调为10m
不停的new 对象,让其撑破Heap最大内存
GC日志分析
YoungGC:
Full GC