首页>新闻>JAVA>详情
苏州JAVA开发应用培训​
预约试听

发布时间:2018-04-08编辑:佚名

苏州JAVA开发应用培训

由于java jdk命令行工具比较重要,加之看到一篇不错的总结,所以接下来详细讲解。

很多java开发人员一旦发现应用无法响应、首先查看一下日志、在查找日志无果的情况下动不动就重启java应用先让其正常工作了再说。还有更为夸张的是听到过制作定时脚本每天半夜定时重启、并笑着说重启解决一切问题。

这种解决办法显然是下下策、经验不足的表现。除了查看日至之外、对于java进程JVM的检测其实sun公司提供了一套强大的虚拟机监视和故障处理工具。如果你对jdk有一点点了解、对于个java 进程的诊断其实就那么回事、我们应该查找到根源问题、从本上找到ava进程不能正常工作的原因、从而达到治本的目的。

简单来介绍一下jdk命令行工具是什么

我们做java的肯定知道jdk的bin目录下面有 java.exe、javac.exe这两个命令行工具。但是除了这两个工具还有一些其他的非常实用的工具、该篇文章主要就是介绍用于监视虚拟机和故障处理的工具。

JPS---虚拟机进程状况工具

常用的参数:

-l 输出Java应用程序的main class的完整包

-q 仅显示pid,不显示其它任何相关信息

-m 输出传递给main方法的参数

-v 输出传递给JVM的参数。在诊断JVM相关问题的时候,这个参数可以查看JVM相关参数的设置

注:这个命令相信大多数java程序员都知晓、查找当前运行的java进程、当需要kill掉某个进程的时候可以用到。

jstat ---虚拟机统计信息监视工具

jstat [ generalOption | outputOptions vmid [interval[s|ms] [count]] ] ,可以用来查看堆信息,垃圾回收信息等,详细使用命令可以**man jstat命令来查看。

查看垃圾回收信息

S0C:年轻代中**个survivor(幸存区)的容量 (字节)

S1C:年轻代中第二个survivor(幸存区)的容量 (字节)

S0U:年轻代中**个survivor(幸存区)目前已使用空间 (字节)

S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节)

EC:年轻代中Eden(伊甸园)的容量 (字节)

EU:年轻代中Eden(伊甸园)目前已使用空间 (字节)

OC:Old代的容量 (字节)

OU:Old代目前已使用空间 (字节)

PC:Perm(持久代)的容量 (字节)

PU:Perm(持久代)目前已使用空间 (字节)

YGC:从应用程序启动到采样时年轻代中gc次数

YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)

FGC:从应用程序启动到采样时old代(全gc)gc次数

FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)

GCT:从应用程序启动到采样时gc用的总时间(s)

NGCMN:年轻代(young)中初始化(**小)的大小 (字节)

NGCMX:年轻代(young)的**大容量 (字节)

NGC:年轻代(young)中当前的容量 (字节)

OGCMN:old代中初始化(**小)的大小 (字节)

OGCMX:old代的**大容量 (字节)

OGC:old代当前新生成的容量 (字节)

PGCMN:perm代中初始化(**小)的大小 (字节)

PGCMX:perm代的**大容量 (字节)

PGC:perm代当前新生成的容量 (字节)

S0:年轻代中**个survivor(幸存区)已使用的占当前容量百分比

S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比

E:年轻代中Eden(伊甸园)已使用的占当前容量百分比

O:old代已使用的占当前容量百分比

P:perm代已使用的占当前容量百分比

S0CMX:年轻代中**个survivor(幸存区)的**大容量 (字节)

S1CMX :年轻代中第二个survivor(幸存区)的**大容量 (字节)

ECMX:年轻代中Eden(伊甸园)的**大容量 (字节)

DSS:当前需要survivor(幸存区)的容量 (字节)(Eden区已满)

TT: 持有次数限制

MTT : **大持有次数限制

jinfo java配置信息工具

观察运行中的java程序的运行环境参数:参数包括Java System属性和JVM命令行参数、也可以设置参数的值,并使之立即生效。

eg:

jmap Java内存映像工具

可以生成java应用程序的堆快照和对象统计信息。

下面的命令可以看到java进程中某一时刻的类示例数量以及所占的字节数。

打印进程的类加载器和类加载器加载的持久代对象信息,输出:类加载器名称、对象是否存活(不可靠)、对象地址、父类加载器、已加载的类大小等信息。

1、使用jmap -heap pid查看进程堆内存使用情况,包括使用的GC算法、堆配置参数和各代中堆内存使用情况。

2、使用jmap -histo[:live] pid 查看堆内存中的对象数目、大小统计直方图,如果带上live则只统计活对象。

也可以将当前程序的堆快照导出到文件中:

jstack命令(Java Stack Trace)

可以用来查看java应用程序的堆栈信息。

jstack -l <pid>

可以用来查看进程中线程状态,检测死锁等。

jstack可以定位到线程堆栈,根据堆栈信息可以定位到具体代码,所以它在JVM性能调优中使用得非常多。下面我们来一个实例找出某个Java进程中**耗费CPU的Java线程并定位堆栈信息,用到的命令有ps、top、printf、jstack、grep。

1.:先找出Java进程ID,我部署在服务器上的Java应用名称为mrf-center:


得到进程ID为21711

2.:找出该进程内**耗费CPU的线程 top -Hp pid


TIME列就是各个Java线程耗费的CPU时间,CPU时间**长的是线程ID为21742的线程

printf"%x "21742得到21742的十六进制值为54ee,下面会用到。

3.:jstack上场、它用来输出进程21711的堆栈信息,然后根据线程ID的十六进制值grep,如下:

PS:可以看到CPU消耗在PollIntervalRetrySchedulerThread这个类的Object.wait(),我找了下我的代码,定位到下面的代码:




咨询联系方式:13861302024(杨老师)或者QQ:2589245390 还可以直接在线咨询

更多JAVA课程推荐:

苏州JAVA培训网

苏州JAVA软件培训

苏州三网IT教育培训

苏州其然软件开发培训

<上一篇:苏州JAVA数据库培训​ >苏州JAVA前端开发培训​下一篇:
1V1课程咨询 免费试听课程

编辑推荐