【Java】jps — 查看进程信息

简介

JVM Process Status Tool,显示指定系统内所有的HotSpot虚拟机进程。

功能: 显示当前所有java进程pid的命令,我们可以通过这个命令来查看到底启动了几个java进程(因为每一个java程序都会独占一个java虚拟机实例)。

缺点: 不过jps有个缺点是只能显示当前用户的进程id,要显示其他用户的还只能用linux的ps命令。

jps -help
输出结果:

root@itfuture:bin #jps -help
usage: jps [-help]
       jps [-q] [-mlvV] [<hostid>]

Definitions:
    <hostid>:      <hostname>[:<port>]

命令格式:

jps [options] [hostid]

option参数:

参数 说明
-l 输出主类全名或jar路径
-q 只输出LVMID
-m 输出JVM启动时传递给main()的参数
-v 输出JVM启动时显示指定的JVM参数 其中 [option]、[hostid] 参数也可以不写。

常用命令

1、jps

列出所有正在运行的java进程,其中jps命令也是一个java程序,前面的数字就是对应的进程id。

jps
输出结果:

root@yzh-zabbix-server:bin #jps
2153 Bootstrap
2697 Jps

2、jps -l

输出应用程序main.class的完整package名或者应用程序jar文件完整路径名。

jps -l
输出结果:

root@yzh-zabbix-server:bin #jps -l
2496 sun.tools.jps.Jps
2153 org.apache.catalina.startup.Bootstrap

3、jps -q
只输出LVMID。

jps -q
输出结果:

1282
24034
7763
24035
7765
45529
427
10174

4、jps -m
输出JVM启动时传递给main()的参数。

jps -m
输出结果:

10256 Jps -m
1282
24034 RemoteMavenServer36
7763 Launcher /Applications/IntelliJ IDEA.app/Contents/lib/netty-common-4.1.52.Final.jar:/Applications/IntelliJ IDEA.app/Contents/lib/netty-resolver-4.1.52.Final.jar:/Applications/IntelliJ
24035 RemoteMavenServer36
7765 Bootstrap start
45529
427

5、jps -v

输出传递给JVM的参数。

jps -v
输出结果:

root@yzh-zabbix-server:bin #jps -v
2153 Bootstrap -Djava.util.logging.config.file=/data/livy/zhengzhouyh/apache-tomcat-7.0.87/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djdk.tls.ephemeralDHKeySize=2048 -javaagent:/data/livy/zhengzhouyh/JavaAgent_2.7.0_zzbank/lib/agent.jar -Djava.rmi.server.hostname=10.0.1.21 -Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.port=18999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Dignore.endorsed.dirs= -Dcatalina.base=/data/livy/zhengzhouyh/apache-tomcat-7.0.87 -Dcatalina.home=/data/livy/zhengzhouyh/apache-tomcat-7.0.87 -Djava.io.tmpdir=/data/livy/zhengzhouyh/apache-tomcat-7.0.87/temp -agentpath:/opt/dynatrace/oneagent/agent/lib64/liboneagentloader.so=loglevelcon=none,tenant=qng16405,tenanttoken=VpaYLCqHrkVjEFBd,server=https://sg-us-west-2-34-214-95-212-prod16-oregon.live.ruxit.com/communication;https://sg-us-west-2-34-208-246-192-prod16-oregon.live.ruxit.com/communication;https://sg-us-west-2-35-161-237-123-prod16-
2860 Jps -Dapplication.home=/usr/local/jdk1.8.0_144 -Xms8m

6、jps失效

我们在定位问题过程会遇到这样一种情况,用 jps 查看不到进程id,用 ps -ef | grep java 却能看到启动的java进程。

要解释这种现象,先来了解下 jps 的实现机制:

java程序启动后,会在目录 /tmp/hsperfdata_{userName}/ 下生成几个文件,文件名就是java进程的 pid ,因此jps列出进程id就是把这个目录下的文件名列一下而已,至于系统参数,则是读取文件中的内容。

我们来思考下:

由于磁盘满了,无法创建这些文件;

用户对这些文件没有读的权限;

因为某种原因这些文件或者目录被清除;

出现以上这些情况,就会导致jps命令失效。

如果jps命令失效,而我们又要获取pid,还可以使用以下两种方法:

top | grep java
ps -ef |grep java

你可能感兴趣的:(编程笔记(问题解决),Java学习知识总结,java,开发语言)