Java性能分析神器--VisualVM Launcher[1]

摘要:
这个插件需要和客户端配合使用VisualVM。安装VisualVM和VisualVMLauncher1.Idea安装VisualVMLauncher插件Preferences--˃Plugins--˃搜索VisualVMLauncher,安装重启即可2.配置IdeaVisualVMLauncher插件Preferences--˃othersettings-˃VisualVMLauncher--˃输入VisualVMexecutable和JDKhome即可3.配置完之后的idea页面4.安装VisualVM客户端http://visualvm.github.io/download.html--˃选择对应的系统安装包--˃对应安装,安装完成后打开是这样的页面:VisualVM和java命令行工具1.jmap+jhat内存快照与分析:HeapDumpHeapDump又叫做堆存储文件,指一个Java进程在某个时间点的内存快照。

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即可

Java性能分析神器--VisualVM Launcher[1]第1张

3. 配置完之后的idea页面

Java性能分析神器--VisualVM Launcher[1]第2张

4. 安装VisualVM客户端

http://visualvm.github.io/download.html --> 选择对应的系统安装包 --> 对应安装,安装完成后打开是这样的页面:

Java性能分析神器--VisualVM Launcher[1]第3张


VisualVM和java命令行工具

1. jmap+jhat内存快照与分析:Heap Dump
  1. HeapDump又叫做堆存储文件,指一个Java进程在某个时间点的内存快照。Heap Dump在触发内存快照的时候会保存此刻的java对象和类的信息。通常在写heap Dump文件前会触发一次FullGC,所以heap dump文件里保存的都是FullCG后留下的对象信息。

  2. jmap进行内存快照方式:

    jmap -dump:format=b,file=<filename.hprof> <pid>

  3. jhat进行内存快照分析:

    • jhat <heap dump file>
    • 使用了jhat命令,就启动了一个http服务,端口是7000,即http://localhost:7000/,就可以在浏览器里分析
  4. VisualVM进行内存快照方式:

    • 在“应用程序”窗口中右键单击应用程序节点,然后选择“堆 Dump”。
    • 在“应用程序”窗口中双击应用程序节点以打开应用程序标签,然后在“监视”标签中单击“堆 Dump”。
  5. VisualVM快照页面,也可以右键保存此时的快照:

    Java性能分析神器--VisualVM Launcher[1]第4张

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

    • 单击“堆 Dump”工具栏中的“类”,以查看活动类和对应实例的列表。
    • 双击某个类名打开“实例”视图,以查看实例列表。
    • 从列表中选择某个实例,以查看对该实例的引用。
2. jinfo:显示虚拟机配置信息(查看虚拟机配置参数信息)
  1. 虚拟机配置信息:JVM的启动参数

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

    jinfo <pid>

  3. Visual VM查看虚拟机配置信息,直接在应用程序打开,就可以看到JVM参数 和 系统属性:

    Java性能分析神器--VisualVM Launcher[1]第5张

  4. 一些常见的虚拟机配置参数:

    • -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查看虚拟机进程信息
  1. 用来查询正在运行的虚拟机进程

  2. jps命令,详情查看

    • jps
  3. VisualVM查看正在运行的虚拟机进程:

    Java性能分析神器--VisualVM Launcher[1]第6张

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

  2. jstack命令,详情查看

    • jstack <pid>
  3. VisualVM生成虚拟机线程快照方式:

    • 在“应用程序”窗口中右键单击应用程序节点,然后选择“线程 Dump”。
    • 在“应用程序”窗口中双击应用程序节点以打开应用程序标签,然后在“线程”标签中单击“线程 Dump”。
  4. VisualVM线程快照页面,也可以右键保存快照:

    Java性能分析神器--VisualVM Launcher[1]第7张

5. jstat收集Hotspot虚拟机各方面的运行数据
  1. 运行数据:对Java应用程序的资源和性能进行实时监控,主要包括GC情况和Heap Size资源使用情况。

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

    • jstat -gc <pid>
  3. VisualVM进行程序资源的实时监控:

    Java性能分析神器--VisualVM Launcher[1]第8张


VisualVM也提供了一些其他功能

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


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


欢迎访问我的个人博客

免责声明:文章转载自《Java性能分析神器--VisualVM Launcher[1]》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇ABAP 上传图片wamp2.4.4 如何配置虚拟主机及反向代理(解决跨域问题)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

如何快速解决虚拟机中的CentOS7无法上网的方式

在日常的学习中,很多时候我们都会用到虚拟机来测试不同的系统,那么想必在大家安装了CentOS7虚拟机后,发现虚拟机无法上网,一定会非常郁闷吧,毕竞有很多的命令是需要连接网络才能实现的,无法上网,那么当然就无法系统完全的测试学习CentOS7系统了! 下面就给大家介绍一个快速解决CentOS7虚拟法上网的方式 首先:打开虚拟机的编辑菜单,选择“虚拟机网络编...

VM虚拟机网络设置

 VM虚拟机网络设置(转) VMWare中的几种网络设置 (1)Bridged方式 用这种方式,虚拟系统的IP可设置成和本机系统在同一网段,虚拟系统相当于网络内的一台独立的机器,和本机一起插在一个Hub上,网络内其他机器可访问虚拟系统,虚拟系统也可访问网络内其他机器,当然和本机系统的双向访问也不成问题。 (2)NAT方式 这种方式也能实现本机系统和虚拟系...

异步 HttpContext.Current实现取值的方法(解决异步Application,Session,Cache...等失效的问题)

在一个项目中,为了系统执行效率更快,把一个经常用到的数据库表通过dataset放到Application中,发现在异步实现中每一次都会出现HttpContext.Current为null的异常,后来在网上查了好多资料,发现问这个问题的人多,回答的少,回答的也多数都是:引用System.Web,不要用HttpContext.Current.Applicati...

虚拟机黑屏无法登入

处理方式一 1.以管理员的身份运行cmd 2.在cmd中输入以下命令 netshwinsockresetnetstopVMAuthdServicenetstartVMAuthdServicenetstopVMwareHostdnetstartVMwareHostd 3.关机重启计算机 4.计算机重启后,重新打开虚拟机。 处理方式二 如果经过处理方式一的处理...

Hyper-V和其他虚拟机共存 【转】

由于Windows中Hyper-V的实现方式在系统中为独占,所以其不能与其他的虚拟机共存。下面的方法是在系统中新增一个启动项,在这个启动项中关闭Hyper-V,这样就可以安装并使用其他虚拟机了。需要使用到Hyper-V的时候进行重启切换。 1、运行 bcdedit /copy {current} /d "Windows 10 Without Hyper-V...

android中Handle类的用法

android中Handle类的用法     当我们在处理下载或是其他需要长时间执行的任务时,如果直接把处理函数放Activity的OnCreate或是OnStart中,会导致执行过程中整个Activity无响应,如果时间过长,程序还会挂掉。Handler就是把这些功能放到一个单独的线程里执行,与Activity互不影响。     当用户点击一个按钮时如果...