Java1.8 JVM配置 GC日志输出

 

                            Java1.8 堆内存模型,移除永久代,变成了元数据区

  由上图可以看出,jdk1.8的内存模型是由2部分组成,年轻代 ,年老代。

    • 年轻代:Eden + 2*Survivor
    • 年老代:OldGen
    • 在jdk1.8中变化最大的Perm区,用Metaspace (元数据空间)进行了替换。

  注意:

    Metaspace所占用的内存空间不是在虚拟机内部,而是在本地内存空间中,这也是与1.7的永久代最大的区别所在

 

1、配置GC日志输出目录,方便分析Gc日志

1
-Xloggc:log/gc.log

 

 

2、配置查看JVMGC日志信息

  

1
2
3
4
-Xmx20m  //最大堆内存
-Xms20m  //最小堆内存
-Xmn3m //新生代大小,大小是:eden+ 2 survivor space
 -XX:+PrintGCDetails //打印GC信息

  运行如下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
package com.tree.blog.jvm;
 
public class JVMTest {
    public static void main(String[] args) {
        byte[] b = null;
        byte[] c = null;
        for (int i = 0; i < 100; i++) {
            //3m 大于 -Xmn2m 直接分配到老生代中
            b = new byte[3 * 1024*1024 ];
            c =b;
        }
    }
}

  控制台输出:

 

  从GC日志中可以看出,GC和FullGC信息,这里没有设置newration,则是按照堆大小减去新生代大小,得到老年代大小的,如何配置了新生代和老年代的比例的话则按照堆的比例来分配内存

    xmx20m 的分配情况

    xmn3m 新生代大小

    老年代大小为20-3m

 3、查询OOM dump文件

  配置dump文件输出目录,使用jdkbin目录下的javaVisualVm查询 OOM信息,打开信息如下

 

 

 

4、发送内存泄露是如何处理,这里可以配置触发脚本

  -XX:OnOutOfMemoryError
    在OOM时,执行一个脚本。
  可以在OOM时,发送邮件,甚至是重启程序。
  例如我们设置如下的参数:

1
-XX:OnOutOfMemoryError=D:/tools/jdk1.7_40/bin/printstack.bat %p //p代表的是当前进程的pid

  

 5、按照堆内存按照比例分配  新/老年代内存

  -XX:NewRatio=4   1:4   1/5

   -XX:SurvivorRatio=8(幸存代) 2:8   

  二八:小占20%,大占80%

参考:

  https://www.cnblogs.com/SaraMoring/p/5713989.html

posted on   滚动的蛋  阅读(6465)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示