Java性能分析神器--VisualVM Launcher[1]
Java性能分析神器1--VisualVM Launcher
VisualVM
当你日复一日敲代码的时候,当你把各种各样的框架集成到一起的时候,看着大功告成成功运行的日志,有没有那么一丝丝迷茫和惆怅:这TM起的是什么玩意?每一行日志背后代表的是什么东西??他为什么就能跑起来了呢????
这种时候不要慌,给大家推荐一款功能强大的插件:VisualVM Launcher。(eclipse就叫 VisualVM)。这个插件需要和客户端配合使用 VisualVM。
VisualVM是集成了命令行JDK工具和轻量级分析功能的可视化工具。JVM提供了一些常用的jdk命令行工具:
- jstat(JVM Statistics Monitoring Tool):用于收集Hotspot虚拟机各方面的运行数据(查看虚拟机各云心状态信息),显示本地或远程虚拟机进程中的类装载,内存,垃圾收集, JIT编译等运行数据。
- jps(JVM Process Status Tool):显示指定系统内所有的HotSpot虚拟机进程(查看虚拟机进程信息),可用于查询正在运行的虚拟机进程, 同时可选择性的显示虚拟机执行主类, 即执行main函数的类, 以及进程的本地虚拟机
ID(Local Virtual Machine Identifier 简称LVMID)(对于本地虚拟机进程来说, 进程的本地虚拟机ID与操作系统的进程ID是一致的) - jinfo(Configuration Info for Java):显示虚拟机配置信息(查看虚拟机配置参数信息),可用于查看和调整虚拟机的配置参数.
- jmap(JVM Memory Map):生成虚拟机的内存转储快照, 生成heapdump文件(生成虚拟机内存转储快照),可用于获取heapdump文件, 且可以查询finalize执行队列, Java堆与永久代的一些信息。
- jhat(JVM Heap Dump Browser):用于分析heapdump文件, 它会建立一个HTTP/HTML服务器, 让用户在浏览器上查看分析结果(分析虚拟机转储快照信息),jhat命令与jmap命令搭配使用, 用于分析jmap生成的堆转储快照, jhat内置了一个微型的HTTP/HTML服务器, 生成dump文件的分析结果后, 可以在浏览器中查看。
- jstack(JVM Stack Trace):显示虚拟机的线程快照(虚拟机堆栈跟踪),用于生成虚拟机当前时刻的线程快照。 线程快照指的是当前虚拟机内的每一条线程正在执行的方法堆栈的集合, 生成线程快照的作用是, 可用于定位线程出现长时间停顿的原因, 如线程间死锁, 死循环, 请求外部资源导致的长时间等待等问题, 当线程出现停顿时 就可以用jstack各个线程调用的堆栈情况
这些工具功能强大,可以很方便的查看jvm内存分配,内存大小,装载类总数,线程总数等。有了这些信息,就可以很快的进程诊断,性能调优辣。
安装VisualVM和VisualVM Launcher
1. Idea安装VisualVM Launcher插件
Preferences --> Plugins --> 搜索VisualVM Launcher,安装重启即可
2. 配置Idea VisualVM Launcher插件
Preferences --> other settings -> VisualVM Launcher --> 输入VisualVM executable 和 JDK home即可
3. 配置完之后的idea页面
4. 安装VisualVM客户端
http://visualvm.github.io/download.html --> 选择对应的系统安装包 --> 对应安装,安装完成后打开是这样的页面:
VisualVM和java命令行工具
1. jmap+jhat内存快照与分析:Heap Dump
HeapDump又叫做堆存储文件,指一个Java进程在某个时间点的内存快照。Heap Dump在触发内存快照的时候会保存此刻的java对象和类的信息。通常在写heap Dump文件前会触发一次FullGC,所以heap dump文件里保存的都是FullCG后留下的对象信息。
jmap进行内存快照方式:
jmap -dump:format=b,file=<filename.hprof> <pid>jhat进行内存快照分析:
jhat <heap dump file>- 使用了jhat命令,就启动了一个http服务,端口是7000,即http://localhost:7000/,就可以在浏览器里分析
VisualVM进行内存快照方式:
- 在“应用程序”窗口中右键单击应用程序节点,然后选择“堆 Dump”。
- 在“应用程序”窗口中双击应用程序节点以打开应用程序标签,然后在“监视”标签中单击“堆 Dump”。
VisualVM快照页面,也可以右键保存此时的快照:
想要打开保存好的java快照:
- 单击“堆 Dump”工具栏中的“类”,以查看活动类和对应实例的列表。
- 双击某个类名打开“实例”视图,以查看实例列表。
- 从列表中选择某个实例,以查看对该实例的引用。
2. jinfo:显示虚拟机配置信息(查看虚拟机配置参数信息)
虚拟机配置信息:JVM的启动参数
jinfo进行查看虚拟机配置信息查询(jinfo -help查看更多)
jinfo <pid>Visual VM查看虚拟机配置信息,直接在应用程序打开,就可以看到JVM参数 和 系统属性:
一些常见的虚拟机配置参数:
- -Xms:初始堆大小。如:-Xms256m
- -Xmx:最大堆大小。如:-Xmx512m
- -Xmn:新生代大小。通常为 Xmx 的 1/3 或 1/4。
- -Xss:为每个线程分配的内存大小,JDK1.5+ 每个线程堆栈大小为 1M,一般来说如果栈不是很深的话, 1M 是绝对够用了的。
- -XX:NewRatio:新生代与老年代的比例,如 –XX:NewRatio=2,则新生代占整个堆空间的1/3,老年代占2/3
- -XX:SurvivorRatio:新生代中 Eden 与 Survivor 的比值。默认值为 8。即 Eden 占新生代空间的 8/10,另外两个 Survivor 各占 1/10
- -XX:PermSize:永久代(方法区)的初始大小
- PermSize永久代的概念在jdk1.8中已经不存在了,取而代之的是metaspace元空间,当认为执行永久代的初始大小以及最大值是jvm会给出如此下提示:
- Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=30m; support was removed in 8.0
- Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=30m; support was removed in 8.0
- PermSize永久代的概念在jdk1.8中已经不存在了,取而代之的是metaspace元空间,当认为执行永久代的初始大小以及最大值是jvm会给出如此下提示:
- -XX:MaxPermSize:永久代(方法区)的最大值
- -XX:+PrintGCDetails:打印 GC 信息
- -XX:+HeapDumpOnOutOfMemoryError:让虚拟机在发生内存溢出时 Dump 出当前的内存堆转储快照,以便分析用
3. jps查看虚拟机进程信息
用来查询正在运行的虚拟机进程
jps命令,详情查看:
jps
VisualVM查看正在运行的虚拟机进程:
4. jstack显示虚拟机的线程快照
生成虚拟机当前时刻的线程快照,用来查找运行时死锁,死循环的原因
jstack命令,详情查看
jstack <pid>
VisualVM生成虚拟机线程快照方式:
- 在“应用程序”窗口中右键单击应用程序节点,然后选择“线程 Dump”。
- 在“应用程序”窗口中双击应用程序节点以打开应用程序标签,然后在“线程”标签中单击“线程 Dump”。
VisualVM线程快照页面,也可以右键保存快照:
5. jstat收集Hotspot虚拟机各方面的运行数据
运行数据:对Java应用程序的资源和性能进行实时监控,主要包括GC情况和Heap Size资源使用情况。
jstat进行资源与性能监控,详情查看:
jstat -gc <pid>
VisualVM进行程序资源的实时监控:
VisualVM也提供了一些其他功能
此外,VisualVM也提供很多插件,有各样的功能,我就不多介绍了
这篇文章,介绍了VisualVM的作用和用法,下面会写一篇姊妹篇 点这里 带上代码,去分析当系统出现死锁或者循环等异常时,内存、线程和CPU在做什么。
Java性能分析神器--VisualVM Launcher[1]的更多相关文章
- 性能分析神器VisualVM【转】
性能分析神器VisualVM[转] Posted on 2015-04-17 09:37 WadeXu 阅读(5809) 评论(6) 编辑 收藏 VisualVM 是一款免费的,集成了多个 JDK 命 ...
- 性能分析神器VisualVM
VisualVM 是一款免费的,集成了多个 JDK 命令行工具的可视化工具,它能为您提供强大的分析能力,对 Java 应用程序做性能分析和调优.这些功能包括生成和分析海量数据.跟踪内存泄漏.监控垃圾回 ...
- Java性能分析神器-JProfiler详解(一)(转)
前段时间在给公司项目做性能分析,从简单的分析Log(GC log, postgrep log, hibernate statitistic),到通过AOP搜集软件运行数据,再到PET测试,感觉时间花了 ...
- Java性能分析神器-JProfiler详解(转)
前段时间在给公司项目做性能分析,从简单的分析Log(GC log, postgrep log, hibernate statitistic),到通过AOP搜集软件运行数据,再到PET测试,感觉时间花了 ...
- Windows平台下,Java性能分析工具VisualVM的Tomcat8的配置
VisualVM在JDK6版本及以上已经自带这个应用. 位置:C:\Program Files (x86)\Java\jdk1.8.0_60\bin\jvisualvm.exe 在Windows环 ...
- 性能测试三十八:Java性能分析神器-JProfiler安装和简单介绍
Jprofiler是一个重量级的工具,需要分别在服务器和windows都装客户端,会损耗性能,用于发现问题后排查问题,而不是常规的监控 JPROFILER工具下载地址:http://www.ej-te ...
- Java虚拟机性能管理神器 - VisualVM(1) 简介 - JVM轻量级监控分析神器
目录(?)[-] 一VisualVM是什么 二如何获取VisualVM 三获取那个版本 四VisualVM能做什么 显示JAVA应用程序配置和运行时环境 显示本地和远程JAVA应用程序运行状态 监控应 ...
- Java 性能分析工具
如何利用 JConsole观察分析Java程序的运行,进行排错调优 http://jiajun.iteye.com/blog/810150 如何使用JVisualVM进行性能分析 http://jia ...
- Java虚拟机性能管理神器 - VisualVM(6) 排查JAVA应用程序内存泄漏【转】
Java虚拟机性能管理神器 - VisualVM(6) 排查JAVA应用程序内存泄漏[转] 标签: javajvm内存泄漏监控工具 2015-03-11 18:30 1870人阅读 评论(0) 收藏 ...
随机推荐
- session,cookie,sessionStorage,localStorage的相关设置以及获取删除
一.cookie 什么是 Cookie? "cookie 是存储于访问者的计算机中的变量.每当同一台计算机通过浏览器请求某个页面时,就会发送这个 cookie.你可以使用 JavaScrip ...
- python编程基础之五
转义字符:就是不方便从键盘之间输出,或者是原字符有特殊含义的一些字符, 下面列举几个常用的转义字符 \',\",\''',\""",\\,都是表示原字符的意思, ...
- python常用算法学习(4)——数据结构
数据结构简介 1,数据结构 数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成.简单来说,数据结构就是设计数据以何种方式组织并存贮在计算机中.比如:列表,集合与字 ...
- 像艺术家一样思考 Think Like an Artist
艺术家是如何获得灵感,如何找到自己的独特风格和主题的? 艺术家在绘画.写作.表演或歌唱前不会去征求谁的允许,而是随心而行 要想在数字时代获得满足感,我们需要变得有创造性 1.艺术家富有事业心 艺术家是 ...
- 域渗透基础之Kerberos认证协议
本来昨晚就该总结整理,又拖到今天早上..6点起来赶可还行 0x01 Kerberos前言 Kerberos 是一种由 MIT(麻省理工大学)提出的一种网络身份验证协议.它旨在通过使用密钥加密技术为客 ...
- HTTPS 验证访问略记
背景 互联网刚刚兴起的时候,网络安全并没有被很好的重视.HTTP 是明文传输的,这为意图谋不道德之事者提供了诸多的便利.当越来越多的人利益受到侵害的时候,开始重视网络传输的安全问题了. HTTPS 加 ...
- [UWP]使用CompositionLinearGradientBrush实现渐变画笔并制作动画
1. 什么是 CompositionBrush CompositionBrush(合成画笔)是操作可视化层时用于绘制 SpriteVisual 区域的画笔. 使UWP 应用时可以选择使用 XAML 画 ...
- vue 详情跳转至列表页 实现列表页缓存
甲爸爸提了一个需求,希望公众号内的商城能够像app一样,从商品详情页跳转至列表页及其他列表页时,可以实现列表页缓存(数据不刷新.位置固定到之前点的商品的位置) 本来想着scrollBehavior应该 ...
- php是做前端的吗?
php是做前端的吗 不是,php是后台脚本语言,由服务器执行. PHP即“超文本预处理器”,是一种通用开源脚本语言.PHP是在服务器端执行的脚本语言,与C语言类似,是常用的网站编程语言.PHP独特的语 ...
- 22.Linux定时任务
1.计划任务时间管理 参数 含义 -e 编辑定时任务 -l 查看定时任务 -r 删除定时任务 -u 指定其他用户 \* 表示任意的(分.时.日.月.周)时间都执行 \- 表示一个时间范围段, 如5-7 ...