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=

jhat进行内存快照分析:

jhat

VisualVM进行内存快照方式:

在“应用程序”窗口中右键单击应用程序节点,然后选择“堆 Dump”。

在“应用程序”窗口中双击应用程序节点以打开应用程序标签,然后在“监视”标签中单击“堆 Dump”。

VisualVM快照页面,也可以右键保存此时的快照:

想要打开保存好的java快照:

单击“堆 Dump”工具栏中的“类”,以查看活动类和对应实例的列表。

双击某个类名打开“实例”视图,以查看实例列表。

从列表中选择某个实例,以查看对该实例的引用。

2. jinfo:显示虚拟机配置信息(查看虚拟机配置参数信息)

虚拟机配置信息:JVM的启动参数

jinfo进行查看虚拟机配置信息查询(jinfo -help查看更多)

jinfo

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

-XX:MaxPermSize:永久代(方法区)的最大值

-XX:+PrintGCDetails:打印 GC 信息

-XX:+HeapDumpOnOutOfMemoryError:让虚拟机在发生内存溢出时 Dump 出当前的内存堆转储快照,以便分析用

3. jps查看虚拟机进程信息

用来查询正在运行的虚拟机进程

jps命令,详情查看:

jps

VisualVM查看正在运行的虚拟机进程:

4. jstack显示虚拟机的线程快照

生成虚拟机当前时刻的线程快照,用来查找运行时死锁,死循环的原因

jstack命令,详情查看

jstack

VisualVM生成虚拟机线程快照方式:

在“应用程序”窗口中右键单击应用程序节点,然后选择“线程 Dump”。

在“应用程序”窗口中双击应用程序节点以打开应用程序标签,然后在“线程”标签中单击“线程 Dump”。

VisualVM线程快照页面,也可以右键保存快照:

5. jstat收集Hotspot虚拟机各方面的运行数据

运行数据:对Java应用程序的资源和性能进行实时监控,主要包括GC情况和Heap Size资源使用情况。

jstat进行资源与性能监控,详情查看:

jstat -gc

VisualVM进行程序资源的实时监控:

VisualVM也提供了一些其他功能

此外,VisualVM也提供很多插件,有各样的功能,我就不多介绍了

这篇文章,介绍了VisualVM的作用和用法,下面会写一篇姊妹篇 点这里 带上代码,去分析当系统出现死锁或者循环等异常时,内存、线程和CPU在做什么。

欢迎访问我的个人博客

java visualvm 教程_Java性能分析神器--VisualVM Launcher[1]相关推荐

  1. 性能分析神器VisualVM

    VisualVM 是一款免费的,集成了多个 JDK 命令行工具的可视化工具,它能为您提供强大的分析能力,对 Java 应用程序做性能分析和调优.这些功能包括生成和分析海量数据.跟踪内存泄漏.监控垃圾回 ...

  2. java火焰评测_JAVA性能分析之使用火焰图

    随着业务的发展,使用接口提供的服务的业务越来越多,不同的业务对调用耗时的要求不同,当然,耗时越少越好.而近来已经有三四个调用方反映接口调用耗时太不稳定,代码上的优化已经做了很多,有效果,但还不够.同时 ...

  3. java dump分析工具_java性能分析与常用工具

    本次源码已放在Github:https://github.com/nateshao/jvm-tuning 个人博客 https://nateshao.gitee.io http://www.nates ...

  4. java性能分析工具_java性能分析工具

    如何利用 JConsole观察分析Java程序的运行,进行排错调优 http://jiajun.iteye.com/blog/810150 如何使用JVisualVM进行性能分析 http://jia ...

  5. idea 查看jsp是否被引用_IDEA集成Java性能分析神器JProfiler

    阅读文本大概需要10分钟. <eclipse集成Java性能分析神器JProfiler>讲解了eclipse集成Jprofiler,这篇讲解一下IDEA如何集成JProfiler. 1.在 ...

  6. explain ref_MySQL 性能分析神器 —— EXPLAIN 用法与解读。

    ↑ 点击上面 "时代Java"关注我们,关注新技术,学习新知识! EXPLAIN作为MySQL的性能分析神器,读懂其结果是很有必要的,然而我在各种搜索引擎上竟然找不到特别完整的解读 ...

  7. 软件性能测试分析与调优实践之路-Java应用程序的性能分析与调优-手稿节选

    Java编程语言自从诞生起,就成为了一门非常流行的编程语言,覆盖了互联网.安卓应用.后端应用.大数据等很多技术领域,因此Java应用程序的性能分析和调优也是一门非常重要的课题.Java应用程序的性能直 ...

  8. jdk工具之JvisualVM、JvisualVM之一--(visualVM介绍及性能分析示例)

    转载:https://www.cnblogs.com/duanxz/p/3713773.html 1.1 Visual VM简介 VisualVM 提供在 Java 虚拟机 (Java Virutal ...

  9. Java性能分析神器-JProfiler详解(一)

    前段时间在给公司项目做性能分析,从简单的分析Log(GC log, postgrep log, hibernate statitistic),到通过AOP搜集软件运行数据,再到PET测试,感觉时间花了 ...

最新文章

  1. 打工皇帝杨元庆年薪达2136万美元 联想称很合理
  2. Python读写json文件中文编码问题
  3. 大数据神器Kafka入门
  4. 完全复制 mysql,MySQL完全复制表结构
  5. 004-JQuery属性
  6. Ubuntu16.04下在Anaconda里面安装opencv
  7. EJB(RMI学习)
  8. Python成员修饰符,metaclass,异常,反射,单例
  9. java .class文件和.class文件区别是什么?
  10. linux下运行二进制文件
  11. 【落谷1957】口算练习题题解
  12. 学海无涯!我总结了所有面试题,含答案解析
  13. php校花评比排名,投票|佛山“校花”颜值大比拼,快来选出你最爱的!
  14. 汇编语言、高级语言(系统语言)、脚本语言的异同
  15. 蓝色基因 p超级计算机,世界最快超级计算机 蓝色基因登陆中国
  16. 二进制安装K8S - NODE 节点的安装
  17. python光棍节快乐_2020年光棍节快乐的祝福语5条
  18. 横板格斗类游戏实战:游戏数值策划表
  19. 如何消除FTP所保存的默认密码
  20. 设计模式原则——单一职责原则

热门文章

  1. mysql中findinset函数的使用
  2. VS2017安装Spy++工具
  3. android mac 照片恢复,相片恢复?误删的手机照片简单的找回方法来了!
  4. 液体效果,制作喷溅的液态裙子教程
  5. 写给需要同程序员打交道的计算机小白们之妹纸汉纸
  6. AUTOSAR实验七 PWM和呼吸灯
  7. SimpleDateFormat类
  8. 量化交易创干货合集送给每一位爱学的宽客qun
  9. 设备安装CoreELEC系统,并配置遥控:实现低成本NAS影音播放器
  10. 新浪微博分享MD5签名生成器没反应