进程查看指令

jps位于jdk的bin目录下,其作用是显示当前系统的java进程情况,及其id号.jps相当于Solaris进程工具ps。不象“pgrep java”或“ps -ef grep java”,jps并不使用应用程序名来查找JVM实例。因此,它查找所有的Java的应用程序,包括即使没有使用的Java执行体的那种(例如,定制的启动器)。另外,JPS仅查找当前用户的Java的进程,而不是当前系统中的所有进程。

 

位置

我们知道,很多的Java命令都在JDK的JAVA_HOME /斌/目录下面,JPS也不例外,他就在仓目录下,所以,他是java的自带的一个命令。

功能

jps(Java虚拟机进程状态工具)是JDK 1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux / unix平台上简单察看当前java进程的一些简单情况。

原理

jdk中的jps命令可以显示当前运行的java进程以及相关参数,它的实现机制如下:
java程序在启动以后,会在java.io.tmpdir指定的目录下,就是临时文件夹里,生成一个类似于hsperfdata_User的文件夹,这个文件夹里(在Linux的中为/ TMP / hsperfdata_ {名} /),有几个文件,名字就是java的进程的PID,因此列出当前运行的java的进程,只是把这个目录里的文件名列一下而已。至于系统的参数什么,就可以解析这几个文件获得。

  1. hollis@hos:/tmp/hsperfdata_hollis$ pwd

  2. /tmp/hsperfdata_hollis

  3. hollis@hos:/tmp/hsperfdata_hollis$ ll

  4. total 48

  5. drwxr-xr-x 2 hollis hollis 4096 4月 16 10:54 ./

  6. drwxrwxrwt 7 root root 12288 4月 16 10:56 ../

  7. -rw------- 1 hollis hollis 32768 4月 16 10:57 2679

  8. hollis@hos:/tmp/hsperfdata_hollis$

上面的内容就是我机器中的/ tmp / hsperfdata_hollis目录下的内容,其中2679就是我机器上当前运行中的Java的的进程的PID,我们执行JPS验证一下:

 
  1. hollis@hos:/tmp/hsperfdata_hollis$ jps

  2. 2679 org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar

  3. 4445 Jps

执行了JPS命令之后,我们发现有两个的java的进程,一个是PID为2679的蚀运行的进程,另外一个是PID为4445的JPS使用的进程(他也是java的的命令,也要开一个进程)

使用

想要学习一个命令,先来看看帮助,使用jps -help查看帮助:

 
  1. hollis@hos:/tmp/hsperfdata_hollis$ jps -help

  2. usage: jps [-help]

  3. jps [-q] [-mlvV] [<hostid>]

  4.  
  5. Definitions:

  6. <hostid>: <hostname>[:<port>]

接下来,为了详细介绍这些参数,我们编写几个类,在主方法里写一个而(真)的循环,查看的java的进程情况代码如下:

 
  1. package com.JavaCommand;

  2. /**

  3. * @author hollis

  4. */

  5. public class JpsDemo {

  6. public static void main(String[] args) {

  7. while(true){

  8. System.out.println(1);

  9. }

  10. }

  11. }

-q只显示PID,不显示类名称,罐子文件名和传递给主方法的参数

 
  1. hollis@hos:/tmp/hsperfdata_hollis$ jps -q

  2. 2679

  3. 11421

-m输出传递给主方法的参数,在嵌入式jvm上可能是null,  在这里,在启动主方法的时候,我给String [] args传递两个参数.hollis,chuang,执行jsp -m

 
  1. hollis@hos:/tmp/hsperfdata_hollis$ jps -m

  2. 12062 JpsDemo hollis,chuang

-l输出应用程序main class的完整包名或者应用程序的jar文件完整路径名

 
  1. hollis@hos:/tmp/hsperfdata_hollis$ jps -l

  2. 12356 sun.tools.jps.Jps

  3. 2679 /home/hollis/tools/eclipse//plugins/org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar

  4. 12329 com.JavaCommand.JpsDemo

-v输出传递给JVM的参数  在这里,在启动主方法的时候,我给jvm传递一个参数:-Dfile.encoding = UTF-8,执行jps -v

 
  1. hollis@hos:/tmp/hsperfdata_hollis$ jps -v

  2. 2679 org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar -Djava.library.path=/usr/lib/jni:/usr/lib/x86_64-linux-gnu/jni -Dosgi.requiredJavaVersion=1.6 -XX:MaxPermSize=256m -Xms40m -Xmx512m

  3. 13157 Jps -Denv.class.path=/home/hollis/tools/java/jdk1.7.0_71/lib:/home/hollis/tools/java/jdk1.7.0_71/jre/lib: -Dapplication.home=/home/hollis/tools/java/jdk1.7.0_71 -Xms8m

  4. 13083 JpsDemo -Dfile.encoding=UTF-8

PS:JPS命令有个地方很不好,似乎只能显示当前用户的java的进程,要显示其他用户的还是只能用Unix / Linux中的PS命令。

JPS是我最常用的Java的的命令。使用JPS可以查看当前有哪些的Java的进程处于运行状态。如果我运行了一个网络应用(使用的Tomcat的,JBoss的的,码头等启动)的时候,我就可以使用JPS查看启动情况。有的时候我想知道这个应用的日志会输出到哪里,或者启动的时候使用了哪些javaagent,那么我可以使用jps -v 查看进程的JVM参数情况。

JPS失效处理

现象:  用ps -ef | grep java能看到启动的java进程,但是用jps查看却不存在该进程的id。待会儿解释过之后就能知道在该情况下,jconsole,jvisualvm可能无法监控该进程,其他的java自带工具也可能无法使用

分析:  jps,jconsole,jvisualvm等工具的数据来源就是这个文件(/ tmp / hsperfdata_userName / pid)。所以当该文件不存在或是无法读取时就会出现jps无法查看该进程号,jconsole无法监控等问题

原因:

(1),磁盘读写,目录权限问题若该用户没有权限写/ tmp目录或是磁盘已满,则无法创建/ tmp / hsperfdata_userName / pid文件。或该文件已经生成,但用户没有读权限

(2),临时文件丢失,被删除或是定期清理对于linux机器,一般都会存在定时任务对临时文件夹进行清理,导致/ tmp目录被清空。这也是我第一次碰到该现象的原因。常用的可能定时删除临时目录的工具为的crontab中,红帽的tmpwatch的,Ubuntu的的tmpreaper等等

这个导致的现象可能会是这样,用JConsole中的监控进程,发现在某一时段后进程仍然存在,但是却没有监控信息了。

(3),java进程信息文件存储地址被设置,不在/ tmp目录下上面我们在介绍时说默认会在/ tmp / hsperfdata_userName目录保存进程信息,但由于以上1,2所述原因,可能导致该文件无法生成或是丢失,所以java的启动时提供了参数(-Djava.io.tmpdir),可以对这个文件的位置进行设置,而JPS,JConsole的都只会从/ TMP目录读取,而无法从设置后的目录读物信息,这是我第二次碰到该现象的原因

附:

1.如何给主传递参数在eclipse中,鼠标右键 - >运行As->运行COnfiguations-> Arguments->在程序参数中写下要传的参数值

1.如何给JVM传递参数在eclipse中,鼠标右键 - >运行方式 - >运行COnfiguations-> Arguments->在VM参数中写下要传的参数值(一般以-D开头)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值