JVM系列(4):堆参数调优

介绍


 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

生命不止,折腾不息
原文地址:https://www.cnblogs.com/steakliu/p/12113485.html