首页 技术 正文
技术 2022年11月14日
0 收藏 436 点赞 4,864 浏览 1090 个字

一、JDK的命令行工具

1、jps(JVM Process Status Tools):虚拟机进程状况工具

jps -l

2、jinfo(Configuration Info for java):Java配置信息工具

jinfo [option] pid  

3、jmap(Memory Map for java):java内存映像工具

用于生成堆转储快照,即dump文件

jmap -dump:format=b,file=eclipse.bin 3500  #3500是通过jps命令拿到的LVMID  

4、jstat(JVM Statistics Monitoring Tool):虚拟机统计信息监视工具

jstat -gc 2764 250 20 # -gc监视java堆状况  每250毫秒查询一次进程2764垃圾收集状态,共查询20次
jstat -gcutil 2754 #监视java堆内存使用状况 
top -p 12309 -H   #-p用于指定进程,-H用于获取每个线程的信息  

5、jhat(JVM Heap Analysis Tool):虚拟机dump文件分析工具

jhat eclipse.bin

屏幕显示“server is ready”,用户在浏览器中键入http://localhost:7000/就可以看到分析结果

6、jstack(Stack Trace for java):java虚拟机自带的堆栈跟踪工具

jstack -l 3500   

jstack命令查看线程堆栈信息时可能会看到的线程的几种状态:

NEW,未启动的。不会出现在Dump中。
RUNNABLE,在虚拟机内执行的。
BLOCKED,受阻塞并等待监视器锁。
WATING,无限期等待另一个线程执行特定操作。
TIMED_WATING,有时限的等待另一个线程的特定操作。
TERMINATED,已退出的。

jstack用于生成java虚拟机当前时刻的线程快照。

线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合。

生成线程快照的主要目的是定位线程出现长时间停顿的原因。

线程长时间停顿的主要原因:等待外部资源(数据库连接、网络资源、设备资源)、死循环、锁等待(活锁和死锁)。

线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做什么事情,或者等待什么资源

二、JDK的可视化工具

JConsole:Java监视与管理控制台

VisualVM:多合一故障处理工具

https://www.ibm.com/developerworks/cn/java/j-lo-visualvm/

三、堆外内存中的直接内存

使用JDK自带的Native Memory Tracking(NMT特性)

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,985
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,501
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,345
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,128
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,763
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,839