• 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

    生命不止,折腾不息
  • 相关阅读:
    [原创] Laravel 启动流程
    修改电脑的TTL返回值
    Apache启动错误解决方法
    RemodelanyWhere11.0.2673版本下载
    函数指针
    指针与数组
    青蛙跳台阶
    旋转数组的最小数字
    对大量人的年龄排序
    泛型算法一
  • 原文地址:https://www.cnblogs.com/steakliu/p/12113485.html
Copyright © 2020-2023  润新知