必知必会的JavaJDK工具
JDK中有很多用于监控诊断的系统工具,对于Java程序员来说,无疑是用来了解自己程序运行时性能好坏的强大工具。
在JDK的bin目录下就可以找到这些工具。
JPS
在Linux有一个命令叫做ps
,可以查看系统当前所有的进程,而JDK提供的jps也是类似,查看正在运行的Java进程。
可以看到该命令的参数。
在默认情况下,jps的输出信息包括Java进程的进程ID以及主类名。
我们还可以通过追加参数,来打印额外的信息。
例如,-l将打印模块名以及包名;
-v将打印传递给 Java 虚拟机的参数(如-XX:+UnlockExperimentalVMOptions -XX:+UseZGC);
-m将打印传递给主类的参数。
也可以使用-lvm一同使用。
在JVM启动时,会创建一个perf memory来存放PerfData,如果使用了参数-XX:-UsePerfData
,禁止其它进程可见,那么jps命令就无法查看到该Java进程了。
Jstat
Jstat命令是用于打印某个Java进程的运行数据。
它支持使用-class
查看类加载相关的数据,-compiler
和-printcompilation
查看即时编译相关的信息。
以及-gc
等垃圾回收相关的数据。
执行时需要指定子命令和Java进程ID。
上图中,S0C和S1C代表了两个Survivor区的大小,C是指Capacity,容量。
S0U和S1U是指两个Survivor区已使用的大小,U是指Utility,实用。
EC和EU代表了Eden区的容量及使用。
OC和OU代表了Old区的容量及使用。
MC和MU代表了方法区的容量及使用。
CCSC和CCSU代表了压缩类空间的容量和使用大小 ,这个相对来说很少使用。
YGC代表了YoungGC,也就是年轻代GC发生的次数,更准确应该叫做MinorGC,YGCT代表所用的时间。
FGC代表FullGC发生的次数,它发生在老年代,FGCT代表所用的时间。
GCT代表所有GC所占用的时间。
可以看到11次YGC只耗时0.439,而8次FGC却用了数倍时间,1.419。
现在我们已经知道每一个标记代表什么了,可以尝试一下使用更详细的gc子命令来查看对应Java进程了。
jstat命令默认执行一次只返回一次,如果我想一直监控某个Java进程,可以添加可以时间参数。
如下图,jstat -gcnew 13496 500
,后面跟一个500,就说明每500ms打印一次。
还可以指定打印的次数,比如jstat -gcnew 13496 500 5
,后面跟500 5
,就说明每500ms打印一次,总共打印5次。
在我们查看内存区域容量变化时,如果发现老年代的使用率不断增加,就说明有大量对象无法进行回收,我们的程序出现了性能上的问题。
再比如,我们可以添加-t
来打印程序运行时间Timestamp,如果GCT占据了大部分程序运行时间,或者说这个时间比在持续上升时。就说明我们程序的堆内存已经在逐步走向奔溃了。
Jmap
知道程序有了问题,我们就可以利用Jmap命令来分析了。
Jmap同样包括多条子命令。
-clstats
,该子命令将打印被加载类的信息。
-finalizerinfo
,该子命令将打印所有待 finalize 的对象。
-histo
,该子命令将统计各个类的实例数目以及占用内存,并按照内存使用量从多至少的顺序排列。此外,-histo:live只统计堆中的存活对象。
-dump
,该子命令将导出 Java 虚拟机堆的快照。同样,-dump:live只保存堆中的存活对象。
我们通常会利用jmap -dump:live,format=b,file=filename.bin
命令,将堆中所有存活对象导出至一个文件之中。
-heap
,该子命令将输出当前堆中的配置信息。
Jinfo
Jinfo命令可用来查看目标Java进程的参数。
Jstack
这是一个非常有用的命令,它可以用来打印目标 Java 进程中各个线程的栈轨迹,以及这些线程所持有的锁,所以这个命令可以帮助我们处理死锁。
我们来写一个简单的会产生死锁的代码。
程序跑着跑着就会发生死锁。
我们使用jstack来查看。
可以看到线程Thread-a
,它locked了String.class这个锁,在waiting等待Main.class
。
而线程Thread-b
,它locked了Main.class
,在waiting等待String.class
。
Jstack甚至帮我们找到了死锁发生的原因。
必知必会的JavaJDK工具的更多相关文章
- 2015 前端[JS]工程师必知必会
2015 前端[JS]工程师必知必会 本文摘自:http://zhuanlan.zhihu.com/FrontendMagazine/20002850 ,因为好东东西暂时没看懂,所以暂时保留下来,供以 ...
- [ 学习路线 ] 2015 前端(JS)工程师必知必会 (2)
http://segmentfault.com/a/1190000002678515?utm_source=Weibo&utm_medium=shareLink&utm_campaig ...
- mysql必知必会
春节放假没事,找了本电子书mysql必知必会敲了下.用的工具是有道笔记的markdown文档类型. 下面是根据大纲已经敲完的章节,可复制到有道笔记的查看,更美观. # 第一章 了解SQL## 什么是S ...
- 关于TCP/IP,必知必会的十个经典问题[转]
关于TCP/IP,必知必会的十个问题 原创 2018-01-25 Ruheng 技术特工队 本文整理了一些TCP/IP协议簇中需要必知必会的十大问题,既是面试高频问题,又是程序员必备基础素养. 一 ...
- 《MySQL必知必会》整理
目录 第1章 了解数据库 1.1 数据库基础 1.1.1 什么是数据库 1.1.2 表 1.1.3 列和数据类型 1.1.4 行 1.1.5 主键 1.2 什么是SQL 第2章 MySQL简介 2.1 ...
- 迈向高阶:优秀Android程序员必知必会的网络基础
1.前言 网络通信一直是Android项目里比较重要的一个模块,Android开源项目上出现过很多优秀的网络框架,从一开始只是一些对HttpClient和HttpUrlConnection简易封装使用 ...
- msql 必知必会笔记
Edit Mysql 必知必会 第一章 理解SQL 什么是数据库 数据库(database) 保存有组织的数据的容器 什么是表 一组特定类型的数据的结构化清单 什么是模式 数据库和表的布局及特性的 ...
- 《SQL必知必会》笔记
SQL必知必会(第4版) 作者:[美]Ben Forta 本书介绍了sql在不同数据库工具(Oracle.SQLite.SQL server.MySQL.MariaDB.PostgreSQL...)是 ...
- TCP/IP 必知必会的十个问题
本文整理了一些TCP/IP协议簇中需要必知必会的十大问题,既是面试高频问题,又是程序员必备基础素养. 一.TCP/IP模型 TCP/IP协议模型(Transmission Control Protoc ...
- TCP/IP,必知必会的
文章目录 前言 TCP/IP模型 数据链路层 网络层 ping Traceroute TCP/UDP DNS TCP连接的建立与终止 TCP流量控制 TCP拥塞控制 0 前言 本文整理了一些TCP/I ...
随机推荐
- Mysql多数据库备份
备份数据脚本 #!/bin/bash # date是linux的一个命令 date [参数] [+格式] time=` date +%Y_%m_%d_%H_%M_%S ` # 备份输出路径 backu ...
- Neo4j:图数据库GraphDB(四)Python中的操作
本文总结下Python中如何操作Neo4j数据库,用到py2neo包,Pip install 一下. 1 连接neo4j数据库:跟其它数据库一样,操作前必须输入用户名和密码及地址连接一下. from ...
- ndnsim结果分析
ndnSIM中提供了几种trace用来对仿真结果进行跟踪,生成数据文件txt 官网地址: https://ndnsim.net/current/metric.html#packet-trace-hel ...
- Halcon一日一练:图像采集设备的基本参数
因操作图像处理之前,需要对图像进行采集.采集图像,我们首先要确定的是图像的像素和采集的效率.这些都需要对设备进行配置与操作.现实情况是图像设备有各自不同的采集方式,配置也各不相同.这就需要设备提供商提 ...
- std::wstring
std::wstring主要用于 UTF-16编码的字符, std::string主要用于存储单字节的字符( ASCII字符集 ),但是也可以用来保存UTF-8编码的字符. UTF-8和UTF-16是 ...
- 利用Veeam保护SAP HANA数据库
利用Veeam保护SAP HANA数据库 前言 针对越来越多的SAP HANA备份需求,我们Team翻译.整理.借鉴了Veeam 的SAP HANA 大神 Clemens Zerbe 和 Ali Sa ...
- springMVC初学简单例子
新建web项目,保留web.xml. 配置web.xml文件(/WEB-INF/下): <?xml version="1.0" encoding="UTF-8&qu ...
- 第二篇:版本控制git之分支
有人把 Git 的分支模型称为它的`‘必杀技特性’',也正因为这一特性,使得 Git 从众多版本控制系统中脱颖而出. 为何 Git 的分支模型如此出众呢? Git 处理分支的方式可谓是难以置信的轻量, ...
- jvm原理和代码运行的过程
一次编译,到处运行 java一直宣传的口号是:一次编译,到处运行.那么它如何实现的呢?我们看下图: graph TD java原程序--javac编译-->java字节码 java字节码--&g ...
- 入门Android底层需要的一些技能
<Android的设计与实现> Android框架层<Linux系统编程手册> Linux系统编程<Android内核剖析> 编译框架和romC语言和Linux内核 ...