zoukankan      html  css  js  c++  java
  • JVM 学习笔记(三)

    一:使用jvisualvm工具查看堆内存

    visualgc插件下载链接 :
    https://visualvm.github.io/pluginscenters.html --->选择对应版本链接--->Tools--->Visual GC
     
    首先我们启动本地工程,不停地往内存中添加对象,代码如下:
    @RestController
    public class HeapController {
        List<Person> list=new ArrayList<Person>();
        @GetMapping("/heap")
        public String heap() throws Exception{
            while(true){
                list.add(new Person());
                Thread.sleep(1);
            }
        }
    }

    使用的是springBoot的工程,启动后访问:localhost:8080/heap

    这样是程序不停地往内存中添加对象

    我们在jvisualvm工具中找到当前进程,如图:

    双击进入如下界面:

     这边可以非常直观地看出jvm中堆的内存分布情况,正好验证了我之前在(二)中的文章所写的那样:

    Survivor区详解:

      由图解可以看出,Survivor区分为两块S0和S1,也可以叫做From和To。在同一个时间点上,S0和S1只能有一个区有数据,另外一个是空的。

      接着上面的GC来说,比如一开始只有Eden区和From中有对象,To中是空的。此时进行一次GC操作,From区中对象的年龄就会+1,我们知道Eden区中所有存活的对象会被复制到To区,From区中还能存活的对象会有两个去处。若对象年龄达到之前设置好的年龄阈值,此时对象会被移动到Old区,如果Eden区和From区没有达到阈值的
    对象会被复制到To区。 此时Eden区和From区已经被清空(被GC的对象肯定没了,没有被GC的对象都有了各自的去处)。这时候From和To交换角色,之前的From变成了To,之前的To变成了From。也就是说无论如何都要保证名为To的Survivor区域是空的。Minor GC会一直重复这样的过程,知道To区被填满,然后会将所有对象复制到老年代中。

     二:堆内存溢出情况

      我们可以适当调节内存的大小,来展示jvm内存溢出的现象,如图,可以在idea中设置jvm堆内存的最大和最小参数:

     运行后访问localhost:9090/heap,等待内存溢出的现象:

     在该工具中可以很明显看出jvm的堆内存已经满了,果然在idea也报了OOM:

    小结

      通过jvisualvm工具,我们可以很直观地看出项目在运行时jvm中堆内存的变化,这个工具还是比较强大的,大家有时间可以试试,今天就分享到这里,还有方法区内存

    和虚拟机栈内存的变化会在下个文章中分析

  • 相关阅读:
    mysql复习相关
    OpenStack三种类型的NAT转换
    openstack资料相关
    [转]Web 调试工具之 Advanced REST client
    [转]Aspose.Words.dll 将 Word 转换成 html
    [Android] 开发第十天
    [win10]遇坑指南
    [转]Explorer.exe的命令行参数
    [Android] 开发第九天
    [Android] 开发第八天
  • 原文地址:https://www.cnblogs.com/talkingcat/p/13269989.html
Copyright © 2011-2022 走看看