老生代一直在gc,当程序继续运行可以发现老生代gc还在继续:

增加到了7次,但是老生代的内存并没有减少。说明存在无法被回收的对象,可能是内存泄漏了。

如何分析是那个对象泄漏了呢?

打开抽样器标签:点击后如下图:

按照程序输出进行堆dump,当输出second时,dump一次,当输出forth时dump一次。

进入最后dump出来的堆标签,点击类:

比较结果如下:

可以看出在两次间隔时间内TestMemory对象实例一直在增加并且多了,说明该对象引用的方法可能存在内存泄漏。

如何查看对象引用关系呢?

右键选择类TestMemory,选择“在实例视图中显示”,如下所示:

左侧是创建的实例总数,右侧上部为该实例的结构,下面为引用说明,从图中可以看出在类CyclicDependencies里面被引用了,并且被HashMap引用。

如此可以确定泄漏的位置,进而根据实际情况进行分析解决。

JVisualVM 远程监控 Tomcat

=========================

  1. 修改远程tomcat的catalina.sh配置文件,在其中增加:

JAVA_OPTS="$JAVA_OPTS

-Djava.rmi.server.hostname=192.168.122.128

-Dcom.sun.management.jmxremote.port=18999

-Dcom.sun.management.jmxremote.ssl=false

-Dcom.sun.management.jmxremote.authenticate=false"

  1. 打开jvisualvm,右键远程,选择添加远程主机:

  2. 输入主机的名称,直接写ip,如下:右键新建的主机,选择添加JMX连接,输入在tomcat中配置的端口即可。

  3. 双击打开。完毕!

  4. JVisualVM 简介

================

VisualVM 是Netbeans的profile子项目,已在JDK6.0 update 7 中自带,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的)。在JDK_HOME/bin(默认是C:\Program Files\Java\jdk1.6.0_13\bin)目录下面,有一个jvisualvm.exe文件,双击打开,从UI上来看,这个软件是基于NetBeans开发的了。

VisualVM 提供了一个可视界面,用于查看 Java 虚拟机 (Java Virtual Machine, JVM) 上运行的基于 Java 技术的应用程序的详细信息。VisualVM 对 Java Development Kit (JDK) 工具所检索的 JVM 软件相关数据进行组织,并通过一种使您可以快速查看有关多个 Java 应用程序的数据的方式提供该信息。您可以查看本地应用程序或远程主机上运行的应用程序的相关数据。此外,还可以捕获有关 JVM 软件实例的数据,并将该数据保存到本地系统,以供后期查看或与其他用户共享。

双击启动 jvisualvm.exe,启动起来后和jconsole 一样同样可以选择本地和远程,如果需要监控远程同样需要配置相关参数。

主界面如下:

VisualVM可以根据需要安装不同的插件,每个插件的关注点都不同,有的主要监控GC,有的主要监控内存,有的监控线程等。

如何安装:

从主菜单中选择“工具”>“插件”。

在“可用插件”标签中,选中该插件的“安装”复选框。单击“安装”。

逐步完成插件安装程序。

我这里以 Eclipse(pid 22296)为例,双击后直接展开,主界面展示了系统和jvm两大块内容,点击右下方jvm参数和系统属性可以参考详细的参数信息.

因为VisualVM的插件太多,我这里主要介绍三个我主要使用几个:监控、线程、Visual GC

监控的主页其实也就是,cpu、内存、类、线程的图表

线程和jconsole功能没有太大的区别

Visual GC 是常常使用的一个功能,可以明显的看到年轻代、老年代的内存变化,以及gc频率、gc的时间等。

以上的功能其实jconsole几乎也有,VisualVM更全面更直观一些,另外VisualVM非常多的其它功能,可以分析dump的内存快照,dump出来的线程快照并且进行分析等,还有其它很多的插件大家可以去探索

案例分析

===========

准备模拟内存泄漏样例

==============

  1. 定义静态变量HashMap

  2. 分段循环创建对象,并加入HashMap

  3. 配置jvm参数如下:

  4. 运行程序并打卡visualvm监控

  5. 查看Visual GC标签,内容如下,这是输出first的截图这是输出forth的截图:

  6. 修改远程tomcat的catalina.sh配置文件,在其中增加:

  7. 打开jvisualvm,右键远程,选择添加远程主机:

  8. 输入主机的名称,直接写ip,如下:右键新建的主机,选择添加JMX连接,输入在tomcat中配置的端口即可。

  9. 双击打开。完毕!

JVisualVM 简介

================

VisualVM 是Netbeans的profile子项目,已在JDK6.0 update 7 中自带,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的)。在JDK_HOME/bin(默认是C:\Program Files\Java\jdk1.6.0_13\bin)目录下面,有一个jvisualvm.exe文件,双击打开,从UI上来看,这个软件是基于NetBeans开发的了。

VisualVM 提供了一个可视界面,用于查看 Java 虚拟机 (Java Virtual Machine, JVM) 上运行的基于 Java 技术的应用程序的详细信息。VisualVM 对 Java Development Kit (JDK) 工具所检索的 JVM 软件相关数据进行组织,并通过一种使您可以快速查看有关多个 Java 应用程序的数据的方式提供该信息。您可以查看本地应用程序或远程主机上运行的应用程序的相关数据。此外,还可以捕获有关 JVM 软件实例的数据,并将该数据保存到本地系统,以供后期查看或与其他用户共享。

双击启动 jvisualvm.exe,启动起来后和jconsole 一样同样可以选择本地和远程,如果需要监控远程同样需要配置相关参数。

主界面如下:

VisualVM可以根据需要安装不同的插件,每个插件的关注点都不同,有的主要监控GC,有的主要监控内存,有的监控线程等。

如何安装:

从主菜单中选择“工具”>“插件”。

在“可用插件”标签中,选中该插件的“安装”复选框。单击“安装”。

逐步完成插件安装程序。

我这里以 Eclipse(pid 22296)为例,双击后直接展开,主界面展示了系统和jvm两大块内容,点击右下方jvm参数和系统属性可以参考详细的参数信息.

因为VisualVM的插件太多,我这里主要介绍三个我主要使用几个:监控、线程、Visual GC

监控的主页其实也就是,cpu、内存、类、线程的图表

线程和jconsole功能没有太大的区别

Visual GC 是常常使用的一个功能,可以明显的看到年轻代、老年代的内存变化,以及gc频率、gc的时间等。

以上的功能其实jconsole几乎也有,VisualVM更全面更直观一些,另外VisualVM非常多的其它功能,可以分析dump的内存快照,dump出来的线程快照并且进行分析等,还有其它很多的插件大家可以去探索

案例分析

===========

准备模拟内存泄漏样例

==============

  1. 定义静态变量HashMap

  2. 分段循环创建对象,并加入HashMap

import java.util.HashMap;

import java.util.Map;public class CyclicDependencies {    //声明缓存对象

private static final Map map = new HashMap();

public static void main(String args[]){        try {            Thread.sleep(10000);//给打开visualvm时间

} catch (InterruptedException e) {            e.printStackTrace();        }        //循环添加对象到缓存        for(int i=0; i<1000000;i++){

TestMemory t = new TestMemory();            map.put(“key”+i,t);

}        System.out.println(“first”);

//为dump出堆提供时间

try {            Thread.sleep(10000);

} catch (InterruptedException e) {            e.printStackTrace();        }        for(int i=0; i<1000000;i++){

TestMemory t = new TestMemory();            map.put(“key”+i,t);

}        System.out.println(“second”);

try {            Thread.sleep(10000);

} catch (InterruptedException e) {            e.printStackTrace();        }        for(int i=0; i<3000000;i++){

TestMemory t = new TestMemory();            map.put(“key”+i,t);

}        System.out.println(“third”);

try {            Thread.sleep(10000);

} catch (

【一线大厂Java面试题解析+核心总结学习笔记+最新架构讲解视频+实战项目源码讲义】浏览器打开:qq.cn.hn/FTf 免费领取

InterruptedException e) {            e.printStackTrace();        }        for(int i=0; i<4000000;i++){

TestMemory t = new TestMemory();            map.put(“key”+i,t);

}        System.out.println(“forth”);

try {            Thread.sleep(Integer.MAX_VALUE);        } catch (InterruptedException e) {            e.printStackTrace();        }        System.out.println(“qqqq”);

}}

  1. 配置jvm参数如下:

-Xms512m

-Xmx512m -XX:-UseGCOverheadLimit -XX:MaxPermSize=50m

  1. 运行程序并打卡visualvm监控

使用JVisualVM分析内存泄漏

=====================

  1. 查看Visual GC标签,内容如下,这是输出first的截图这是输出forth的截图:

通过2张图对比发现:

Java性能调优:利用VisualVM进行性能分析相关推荐

  1. java必读书籍_最佳5本Java性能调优书籍–精选,必读

    java必读书籍 为什么Java开发人员应该阅读有关性能调优的书? 当我很久以前第一次面对这个问题时,我以为以后会做,但是我很长一段时间都没有回过头来. 仅当我在用Java编写的任务关键型服务器端财务 ...

  2. 最佳5本Java性能调优书籍–精选,必读

    为什么Java开发人员应该阅读有关性能调优的书? 当我很久以前第一次面对这个问题时,我以为以后会做,但是我很长一段时间都没有回过头来. 仅当我在用Java编写的任务关键型服务器端财务应用程序中遇到严重 ...

  3. 为什么对 Java 性能调优最后都像在调 you?

    不知道你有没有发现,优化Java,或者任何其他语言的代码性能经常被当做是一种暗黑艺术. 性能分析有种神秘感.画面类似是这样的:一个「黑客」经过多年练就的手艺,能够快速深入了解某个系统,并提出神奇的解决 ...

  4. Java性能调优工具:MAT内存分析工具,上万字带你彻底了解

    MAT内存分析工具 MAT是MemoryAnalyzerTool的简称,它是一款功能强大的Java堆内存分析器,可以用于查找内存泄漏以及查看内存消耗情况.MAT是 基于Eclipse开发的一款免费的性 ...

  5. 发布即巅峰:Java性能调优六大工具:MAT内存分析工具

    MAT内存分析工具 MAT是MemoryAnalyzerTool的简称,它是一款功能强大的Java堆内存分析器,可以用于查找内存泄漏以及查看内存消耗情况.MAT是 基于Eclipse开发的一款免费的性 ...

  6. 千字详解:“Java性能调优六大工具”之JConsole工具

    JConsole工具是JDK自带的图形化性能监控工具. 通过JConsole工具, 可以查看Java应用程序的运行概况, 并监控堆信息. 永久区使用情况及类的加载情况等. 本文主要介绍JConsole ...

  7. 《Java性能调优实战》笔记(一)Java编程性能调优、多线程性能优化

    文章目录 一.Java性能调优概述 1.1 性能调优标准 1.2 制定性能调优策略 二.Java编程性能调优 2.1 字符串 2.2 正则表达式 2.3 ArrayList和LinkedList的选择 ...

  8. java性能调优实战学习笔记

    这是极客时间专栏<java性能调优实战>的部分学习笔记,个人感觉这个专栏内容不深,适合初学者,我只看了编程性能调优和数据库性能调优两块,其他的暂时不打算看了,后续有时间再看吧 有任何问题可 ...

  9. 还搞不懂性能调优?让你见识这份《Java性能调优PDF》啃完你就知道多厉害了!

    Java 应用性能优化是一个老生常谈的话题,典型的性能问题如页面响应慢.接口超时,服务器负载高.并发数低,数据库频繁死锁等.尤其是在"糙快猛"的互联网开发模式大行其道的今天,随着系 ...

  10. 11 个简练的 Java 性能调优技巧

    转载自 11 个简练的 Java 性能调优技巧 想要让你的项目一直高性能运作吗?以下有一些技巧你可以拿去消除缓存瓶颈,还有一些其他的性能调优建议. 大多数开发者认为性能优化是一个复杂的话题,它需要大量 ...

最新文章

  1. Linux shell脚本判断服务器网络是否可以上网
  2. 【Consul】Consul实践指导-健康检查(Checks)
  3. android view getx 0,Android动画:解决通过View.getY()获取初始位置为0的问题
  4. 手机MMI体系结构及其实现
  5. 送书 | 一本针对零基础 AI 学习的书:Python入门到人工智能实战
  6. 最前沿的容器技术有哪些?腾讯、华为、思科等 6 位顶尖专家为你解答!
  7. 14 递归 匿名函数 内置函数
  8. python作用域链_Python 中的作用域准则
  9. SOA面向服务架构详解
  10. python验证软件签名
  11. Cgroup 资源配置方法
  12. 论文笔记-------Topological sound
  13. 人体动作捕捉与SMPL模型 (mocap and SMPL model)
  14. gcc编译-m32、-mx32有什么区别
  15. python字母对照表_Python获取字母表
  16. 003 愚人节的“礼物”
  17. 第18章异步编程-bloc-自定义状态管理示例-BlocProvider
  18. 蓝牙路由器是怎么回事?
  19. SpringBoot工程如何打war包进行云部署
  20. linux命令之打包和解压

热门文章

  1. (13)Verilog HDL变量:memory型
  2. 嵌入式 U 盘自动挂载
  3. java flink项目_IDEA上运行Flink任务的实战教程
  4. java textvaluechanged 全选删除不触发_js动态改变input的值不触发input的change事件的解决办法...
  5. js实现excel块拖拉数据_小程序导出数据到excel表,借助云开发云函数实现excel数据的保存...
  6. 数字图像处理(四)——图像编码技术(一)
  7. 数据结构之二叉排序树
  8. Netfilter框架
  9. 【设计模式】第八章 适配器模式
  10. WPF RichTextBox自动调整高度