0
点赞
收藏
分享

微信扫一扫

JVM系列笔GC与调优2.md

禾木瞎写 2022-04-03 阅读 100

了解HotSpot常用命令行参数

常见和本文中可能用到的参数记录一下,具体垃圾回收器的参数后续调优的详细说明。

参数说明
-Xmx最大可用内存
-Xms初始内存,一般和-Xmx相同,避免重新分配
-Xmn年轻代大小,JVM内存=年轻代+老年代大小+永久代(一般64M)
-XX:+PrintFlagsInitial打印默认参数值
-XX:+PrintFlagsFinal打印最终参数值
-XX:+PrintGC
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps打印GC情况、GC详细日志、GC日志时间戳

常见垃圾回收器组合参数设定:(1.8)

如何查看JVM默认的垃圾回收器?

  1. java -XX:+PrintCommandLineFlags -version

[图片上传失败...(image-6d328d-1648986139688)]

  1. 通过GC日志来辨别是何种垃圾回收器

常见垃圾回收器组合参数设定:(1.8版本的)

>1\. ​	-XX:+UseSerialGC = Serial New (DefNew) + Serial Old		小型程序使用,默认情况下不会是这种选项,HotSpot会根据计算及配置和JDK版本自动选择收集器
>2\. ​	-XX:+UseParNewGC = ParNew + SerialOld  这个组合已经很少用(在某些版本中已经废弃)
>3\. ​	-XX:+UseConc(urrent)MarkSweepGC = ParNew + CMS + Serial Old
>4\. ​	-XX:+UseParallelGC = Parallel Scavenge + Parallel Old (1.8默认) 【PS + SerialOld】
>5\. ​	-XX:+UseParallelOldGC = Parallel Scavenge + Parallel Old
>6\. ​	-XX:+UseG1GC = G1

PS的GC日志详解

每一种垃圾回收器的日志是不一样。这里提供一个样例来详细解释PS的GC日志。

public class HelloGC{
    public static void main(String[] args){
        System.out.println("HelloGC!");
        List list = new ArrayList();
        for(;;){
            // 死循环中每次分配1M大小的数组,存放在list中,JVM内存不足的时候会产生GC
            byte[] b = new byte[1024*1024];
            list.add(b);
        }   
    }
}

编译后启动命令:java -Xmn10M -Xms40M -Xmx60M -XX:+PrintCommandLineFlags -XX:+PrintGC -XX:+UseParallelGC HelloGC

这里设置了最大内存为60M,初始内存为40M,新生代的内存为10M,使用PS垃圾回收器,并打印GC的回收情况。程序运行很快就会产生GC日志。

回收的日志情况:

[图片上传失败...(image-3c8f14-1648986139687)]

HeapDump情况,0x000xxxx内存地址指的是:起始地址、使用空间结束地址、整体空间结束地址;
[图片上传失败...(image-fee8c9-1648986139687)]

举报

相关推荐

0 条评论