Java性能调优:利用VisualVM进行性能分析
老生代一直在gc,当程序继续运行可以发现老生代gc还在继续:
增加到了7次,但是老生代的内存并没有减少。说明存在无法被回收的对象,可能是内存泄漏了。
如何分析是那个对象泄漏了呢?
打开抽样器标签:点击后如下图:
按照程序输出进行堆dump,当输出second时,dump一次,当输出forth时dump一次。
进入最后dump出来的堆标签,点击类:
比较结果如下:
可以看出在两次间隔时间内TestMemory对象实例一直在增加并且多了,说明该对象引用的方法可能存在内存泄漏。
如何查看对象引用关系呢?
右键选择类TestMemory,选择“在实例视图中显示”,如下所示:
左侧是创建的实例总数,右侧上部为该实例的结构,下面为引用说明,从图中可以看出在类CyclicDependencies里面被引用了,并且被HashMap引用。
如此可以确定泄漏的位置,进而根据实际情况进行分析解决。
JVisualVM 远程监控 Tomcat
=========================
- 修改远程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"
打开jvisualvm,右键远程,选择添加远程主机:
输入主机的名称,直接写ip,如下:右键新建的主机,选择添加JMX连接,输入在tomcat中配置的端口即可。
双击打开。完毕!
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出来的线程快照并且进行分析等,还有其它很多的插件大家可以去探索
案例分析
===========
准备模拟内存泄漏样例
==============
定义静态变量HashMap
分段循环创建对象,并加入HashMap
配置jvm参数如下:
运行程序并打卡visualvm监控
查看Visual GC标签,内容如下,这是输出first的截图这是输出forth的截图:
修改远程tomcat的catalina.sh配置文件,在其中增加:
打开jvisualvm,右键远程,选择添加远程主机:
输入主机的名称,直接写ip,如下:右键新建的主机,选择添加JMX连接,输入在tomcat中配置的端口即可。
双击打开。完毕!
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出来的线程快照并且进行分析等,还有其它很多的插件大家可以去探索
案例分析
===========
准备模拟内存泄漏样例
==============
定义静态变量HashMap
分段循环创建对象,并加入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”);
}}
- 配置jvm参数如下:
-Xms512m
-Xmx512m -XX:-UseGCOverheadLimit -XX:MaxPermSize=50m
- 运行程序并打卡visualvm监控
使用JVisualVM分析内存泄漏
=====================
- 查看Visual GC标签,内容如下,这是输出first的截图这是输出forth的截图:
通过2张图对比发现:
Java性能调优:利用VisualVM进行性能分析相关推荐
- java必读书籍_最佳5本Java性能调优书籍–精选,必读
java必读书籍 为什么Java开发人员应该阅读有关性能调优的书? 当我很久以前第一次面对这个问题时,我以为以后会做,但是我很长一段时间都没有回过头来. 仅当我在用Java编写的任务关键型服务器端财务 ...
- 最佳5本Java性能调优书籍–精选,必读
为什么Java开发人员应该阅读有关性能调优的书? 当我很久以前第一次面对这个问题时,我以为以后会做,但是我很长一段时间都没有回过头来. 仅当我在用Java编写的任务关键型服务器端财务应用程序中遇到严重 ...
- 为什么对 Java 性能调优最后都像在调 you?
不知道你有没有发现,优化Java,或者任何其他语言的代码性能经常被当做是一种暗黑艺术. 性能分析有种神秘感.画面类似是这样的:一个「黑客」经过多年练就的手艺,能够快速深入了解某个系统,并提出神奇的解决 ...
- Java性能调优工具:MAT内存分析工具,上万字带你彻底了解
MAT内存分析工具 MAT是MemoryAnalyzerTool的简称,它是一款功能强大的Java堆内存分析器,可以用于查找内存泄漏以及查看内存消耗情况.MAT是 基于Eclipse开发的一款免费的性 ...
- 发布即巅峰:Java性能调优六大工具:MAT内存分析工具
MAT内存分析工具 MAT是MemoryAnalyzerTool的简称,它是一款功能强大的Java堆内存分析器,可以用于查找内存泄漏以及查看内存消耗情况.MAT是 基于Eclipse开发的一款免费的性 ...
- 千字详解:“Java性能调优六大工具”之JConsole工具
JConsole工具是JDK自带的图形化性能监控工具. 通过JConsole工具, 可以查看Java应用程序的运行概况, 并监控堆信息. 永久区使用情况及类的加载情况等. 本文主要介绍JConsole ...
- 《Java性能调优实战》笔记(一)Java编程性能调优、多线程性能优化
文章目录 一.Java性能调优概述 1.1 性能调优标准 1.2 制定性能调优策略 二.Java编程性能调优 2.1 字符串 2.2 正则表达式 2.3 ArrayList和LinkedList的选择 ...
- java性能调优实战学习笔记
这是极客时间专栏<java性能调优实战>的部分学习笔记,个人感觉这个专栏内容不深,适合初学者,我只看了编程性能调优和数据库性能调优两块,其他的暂时不打算看了,后续有时间再看吧 有任何问题可 ...
- 还搞不懂性能调优?让你见识这份《Java性能调优PDF》啃完你就知道多厉害了!
Java 应用性能优化是一个老生常谈的话题,典型的性能问题如页面响应慢.接口超时,服务器负载高.并发数低,数据库频繁死锁等.尤其是在"糙快猛"的互联网开发模式大行其道的今天,随着系 ...
- 11 个简练的 Java 性能调优技巧
转载自 11 个简练的 Java 性能调优技巧 想要让你的项目一直高性能运作吗?以下有一些技巧你可以拿去消除缓存瓶颈,还有一些其他的性能调优建议. 大多数开发者认为性能优化是一个复杂的话题,它需要大量 ...
最新文章
- Linux shell脚本判断服务器网络是否可以上网
- 【Consul】Consul实践指导-健康检查(Checks)
- android view getx 0,Android动画:解决通过View.getY()获取初始位置为0的问题
- 手机MMI体系结构及其实现
- 送书 | 一本针对零基础 AI 学习的书:Python入门到人工智能实战
- 最前沿的容器技术有哪些?腾讯、华为、思科等 6 位顶尖专家为你解答!
- 14 递归 匿名函数 内置函数
- python作用域链_Python 中的作用域准则
- SOA面向服务架构详解
- python验证软件签名
- Cgroup 资源配置方法
- 论文笔记-------Topological sound
- 人体动作捕捉与SMPL模型 (mocap and SMPL model)
- gcc编译-m32、-mx32有什么区别
- python字母对照表_Python获取字母表
- 003 愚人节的“礼物”
- 第18章异步编程-bloc-自定义状态管理示例-BlocProvider
- 蓝牙路由器是怎么回事?
- SpringBoot工程如何打war包进行云部署
- linux命令之打包和解压
热门文章
- (13)Verilog HDL变量:memory型
- 嵌入式 U 盘自动挂载
- java flink项目_IDEA上运行Flink任务的实战教程
- java textvaluechanged 全选删除不触发_js动态改变input的值不触发input的change事件的解决办法...
- js实现excel块拖拉数据_小程序导出数据到excel表,借助云开发云函数实现excel数据的保存...
- 数字图像处理(四)——图像编码技术(一)
- 数据结构之二叉排序树
- Netfilter框架
- 【设计模式】第八章 适配器模式
- WPF RichTextBox自动调整高度