示例三:-flag [+|-]name
命令:jinfo -flag [+|-]name pid
描述:开启或者关闭对应名称的参数
使用 jinfo 可以在不重启虚拟机的情况下,可以动态的修改 jvm 的参数。尤其在线上的环境特别有用。
使用如下:
示例四:-flag name=value
命令:jinfo -flag name=value pid
描述:修改指定参数的值。
同示例三,但示例三主要是针对 boolean 值的参数设置的。
如果是设置 value值,则需要使用 name=value 的形式。
使用如下:
注意事项 :
jinfo虽然可以在java程序运行时动态地修改虚拟机参数,但并不是所有的参数都支持动态修改
示例五: -flags
命令:jinfo -flags pid
描述:输出全部的参数
示例六:-sysprops
命令:jinfo -sysprops pid
描述:输出当前 jvm 进行的全部的系统属性
4.jmap
官网地址:<https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jmap.html>
概述
命令jmap是一个多功能的命令。它可以生成 java 程序的 dump 文件, 也可以查看堆内对象示例的统计信息、查看 ClassLoader 的信息以及 finalizer 队列。
jmap 用法
参数:
option: 选项参数。
pid: 需要打印配置信息的进程ID。
executable: 产生核心dump的Java可执行文件。
core: 需要打印配置信息的核心文件。
server-id 可选的唯一id,如果相同的远程主机上运行了多台调试服务器,用此选项参数标识服务器。
remote server IP or hostname 远程调试服务器的IP地址或主机名。
option
no option: 查看进程的内存映像信息,类似 Solaris pmap 命令。
heap: 显示Java堆详细信息
histo[:live]: 显示堆中对象的统计信息
**clstats:**打印类加载器信息
finalizerinfo: 显示在F-Queue队列等待Finalizer线程执行finalizer方法的对象
**dump::**生成堆转储快照
F: 当-dump没有响应时,使用-dump或者-histo参数. 在这个模式下,live子参数无效.
**help:**打印帮助信息
**J:**指定传递给运行jmap的JVM的参数
示例一:no option
命令:jmap pid
描述:查看进程的内存映像信息,类似 Solaris pmap 命令。
使用不带选项参数的jmap打印共享对象映射,将会打印目标虚拟机中加载的每个共享对象的起始地址、映射大小以及共享对象文件的路径全称。这与Solaris的pmap工具比较相似。
示例二:heap
命令:jmap -heap pid
描述:显示Java堆详细信息
打印一个堆的摘要信息,包括使用的GC算法、堆配置信息和各内存区域内存使用信息
C:\Users\jjs>jmap -heap 5932 Attaching to process ID 5932, please wait... Debugger attached successfully. Server compiler detected. JVM version is 25.91-b15 using thread-local object allocation. Parallel GC with 4 thread(s) Heap Configuration: MinHeapFreeRatio = 0 MaxHeapFreeRatio = 100 MaxHeapSize = 1073741824 (1024.0MB) NewSize = 42991616 (41.0MB) MaxNewSize = 357564416 (341.0MB) OldSize = 87031808 (83.0MB) NewRatio = 2 SurvivorRatio = 8 MetaspaceSize = 21807104 (20.796875MB) CompressedClassSpaceSize = 1073741824 (1024.0MB) MaxMetaspaceSize = 17592186044415 MB G1HeapRegionSize = 0 (0.0MB) Heap Usage: PS Young Generation Eden Space: capacity = 60293120 (57.5MB) used = 44166744 (42.120689392089844MB) free = 16126376 (15.379310607910156MB) 73.25337285580842% used From Space: capacity = 5242880 (5.0MB) used = 0 (0.0MB) free = 5242880 (5.0MB) 0.0% used To Space: capacity = 14680064 (14.0MB) used = 0 (0.0MB) free = 14680064 (14.0MB) 0.0% used PS Old Generation capacity = 120061952 (114.5MB) used = 19805592 (18.888084411621094MB) free = 100256360 (95.6119155883789MB) 16.496143590935453% used 20342 interned Strings occupying 1863208 bytes.
示例三:histo[:live]
命令:jmap -histo:live pid
描述:显示堆中对象的统计信息
其中包括每个Java类、对象数量、内存大小(单位:字节)、完全限定的类名。打印的虚拟机内部的类名称将会带有一个’*’前缀。如果指定了live子选项,则只计算活动的对象。
示例四:clstats
命令:jmap -clstats pid
描述:打印类加载器信息
-clstats是-permstat的替代方案,在JDK8之前,-permstat用来打印类加载器的数据
打印Java堆内存的永久保存区域的类加载器的智能统计信息。对于每个类加载器而言,它的名称、活跃度、地址、父类加载器、它所加载的类的数量和大小都会被打印。此外,包含的字符串数量和大小也会被打印。
示例五:finalizerinfo
命令:jmap -finalizerinfo pid
描述:打印等待终结的对象信息
Number of objects pending for finalization: 0 说明当前F-QUEUE队列中并没有等待Fializer线程执行final
示例六:dump:
命令:jmap -dump:format=b,file=heapdump.phrof pid
描述:生成堆转储快照dump文件。
以hprof二进制格式转储Java堆到指定filename的文件中。live子选项是可选的。如果指定了live子选项,堆中只有活动的对象会被转储。想要浏览heap dump,你可以使用jhat(Java堆分析工具)读取生成的文件。
这个命令执行,JVM会将整个heap的信息dump写入到一个文件,heap如果比较大的话,就会导致这个过程比较耗时,并且执行的过程中为了保证dump的信息是可靠的,所以会暂停应用, 线上系统慎用。
5.jhat
官网:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jhat.html
该jhat命令解析Java堆转储文件并启动Web服务器。该jhat命令使您可以使用自己喜欢的Web浏览器浏览堆转储。该jhat命令支持预先设计的查询,例如显示已知类的所有实例MyClass以及对象查询语言(OQL)。OQL与SQL类似,除了查询堆转储。可从jhat命令显示的OQL帮助页面获得有关OQL的帮助。使用默认端口,可以从http//localhost:7000/oqlhelp /获得OQL帮助。
案例:
1.导出dump信息到a.bin文件
2.启动jhat进行分析文件
3.浏览器查看
Heap Histogram
OQL
6.jstack
官方地址:
https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstack.html
jstack是jdk自带的线程堆栈分析工具,使用该命令可以查看或导出 Java 应用程序中线程堆栈信息。
例子:
高手是如何用jstack找到异常代码的
jvm 性能调优工具之 jstack(用法+死锁案例)
演示:
方式1:直接查看堆栈信息
方式2:
java用thread的api有个方法:Thread.getAllStackTraces().也可以查看堆栈信息。
打印结果如下:
二、可视化工具
1.jconsole
该jconsole命令启动图形控制台工具,使您可以监视和管理本地或远程计算机上的Java应用程序和虚拟机。
官网地址:<https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jconsole.html>
①内存监控
写个demo测试下:
public class JconsoleTest { public byte[] b1 = new byte[128 * 1024]; public static void main(String[] args) { try { Thread.sleep(5000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println("start .."); fill(1000); } private static void fill(int n) { ArrayList<JconsoleTest> jlist = new ArrayList<>(); for (int i=0;i<n;i++){ try { Thread.sleep(100); }catch (InterruptedException e){ e.printStackTrace(); } jlist.add(new JconsoleTest()); } } }
cmd中输入jconsole
查看堆和线程等信息的变化:
②线程监控
public class Main { public static void main(String[] args) { //创建一个输入流,让程序卡在这里 Scanner sc = new Scanner(System.in); sc.next(); new Thread(new Runnable() { @Override public void run() { while(true){ } } },"while true线程").start(); sc.next(); testWait(new Object()); } private static void testWait(Object obj) { System.out.println("----testWait-------"); new Thread(new Runnable() { @Override public void run() { synchronized (obj){ try { obj.wait(); }catch (InterruptedException e){ e.printStackTrace(); } } } },"testWait 线程").start(); } }
监控输入流的线程
监控runnable线程
监控wait线程
③线程死锁监控
测试代码
public class DeadLock implements Runnable { private Object obj1; private Object obj2; public DeadLock(Object obj1, Object obj2) { this.obj1 = obj1; this.obj2 = obj2; } @Override public void run() { synchronized (obj1){ try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } synchronized (obj2){ System.out.println("Hello"); } } } }
public class Main { public static void main(String[] args) { Object obj1 = new Object(); Object obj2 = new Object(); new Thread(new DeadLock(obj1, obj2)).start(); new Thread(new DeadLock(obj2, obj1)).start(); } }
使用jconsole查看
点击检测死锁
2.visualVM
VisualVM是一个以监控、显示本地或者远程服务器 JVM工作情况,进行性能调优的工具。借助VisualVM,我们可以实现对JVM内存各个子池、CPU、垃圾收集器等方面进行监控,从而发现程序代码中潜在的泄露点和配置问题。
VisualVM是一个Java编写的绿色软件,属于开源范畴。VisualVM是使用插件Plugin的方式提供功能,默认提供了一些基本检测功能。如果需要进行拓展,可以使用下载插件的功能进行。
下载地址: https://visualvm.github.io/index.html
插件下载地址:https://visualvm.github.io/pluginscenters.html
①安装:
安装完毕,打开exe
如果打开了idea或者eclipse,可以在左侧菜单栏看到:
可以看到,各种idea的各种信息
②插件下载
可以用这个地址:
插件下载地址:<https://visualvm.github.io/pluginscenters.html
也可以:
在线安装:
完