@mritd
2016-03-14T13:24:02.000000Z
字数 1746
阅读 2746
Java
本文参考自 HollisChuang's Blog
jps 命令用于查看当前 java 进程及其 pid 等相关信息,同 ps -aux | grep java 这种命令不同的是,jps 并不依赖于应用程序名来搜索进程(比如 grep java ); 这使得它可以显示出没有执行体的 java 进程;该命令 1.5+ 可用。
在 Java 程序运行后,其会在 java.io.tmpdir 参数指定的位置生成一个 hsperfdata_{UserName} 的目录,该目录下会生成类似 Linux 程序运行时的二进制 pid 文件,jsp 命令实质上就是列出该目录下的所有文件;其相关信息通过解析该文件获取。在 Linux 系统下,这个目录位于 /tmp/hsperfdata_{UserName},示例如下:

首先可以查看 jps 命令的帮助,获取相关信息,执行 jps --help 如下:

-q 参数只显示pid,不显示class名称,jar文件名和传递给main 方法的参数
[mritd@iZ257uxyg2vZ ~]$ jps -q1743315645[mritd@iZ257uxyg2vZ ~]$
-m 输出传递给 main 方法的参数,在嵌入式jvm上可能是null
[mritd@iZ257uxyg2vZ ~]$ jps -m17478 Jps -m15645 Bootstrap start[mritd@iZ257uxyg2vZ ~]$
-l 参数输出应用程序main class的完整package名 或者 应用程序的jar文件完整路径名
[mritd@iZ257uxyg2vZ ~]$ jps -l17498 sun.tools.jps.Jps15645 org.apache.catalina.startup.Bootstrap[mritd@iZ257uxyg2vZ ~]$
-v 参数输出传递给JVM的参数
[mritd@iZ257uxyg2vZ ~]$ jps -v15645 Bootstrap -Djava.util.logging.config.file=/home/mritd/usr/local/apache-tomcat-8.0.32/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/home/mritd/usr/local/apache-tomcat-8.0.32/endorsed -Dcatalina.base=/home/mritd/usr/local/apache-tomcat-8.0.32 -Dcatalina.home=/home/mritd/usr/local/apache-tomcat-8.0.32 -Djava.io.tmpdir=/home/mritd/usr/local/apache-tomcat-8.0.32/temp17518 Jps -Dapplication.home=/home/mritd/usr/local/jdk1.8.0_73 -Xms8m[mritd@iZ257uxyg2vZ ~]$
-V 参数输出通过标记的文件传递给JVM的参数( .hotspotrc 文件,或者是通过参数 -XX:Flags=<filename> 指定的文件)。
[mritd@iZ257uxyg2vZ ~]$ jps -V17595 Jps15645 Bootstrap[mritd@iZ257uxyg2vZ ~]$
hostid 即 服务器标识,它指定了目标的服务器,它的语法如下:
[protocol:][[//]hostname][:port][/servername]
protocol及 hostname 都没有指定,那表示的是与当前环境相关的本地协议,如果指定了 hostname 却没有指定 protocol,那么 protocol 的默认就是 rmi。rmi 的端口,如果没有指定则默认为 1099。RMI 注册中心中的 jstatd 的名称。