首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

Jps介绍以及解决jps无法查看某个已经启动的java进程有关问题

2012-10-21 
Jps介绍以及解决jps无法查看某个已经启动的java进程问题对于jps较熟悉可以直接查看第二部分的分析?1、jps的

Jps介绍以及解决jps无法查看某个已经启动的java进程问题

对于jps较熟悉可以直接查看第二部分的分析

?

1、jps的作用

jps类似linux的ps命令,不同的是ps是用来显示进程,而jps只显示java进程,准确的说是当前用户已启动的部分java进程信息,信息包括进程号和简短的进程command。

?

2、某个java进程已经启动,用jps却显示不了该进程进程号

这个问题已经碰到过两次了,所以在这里总结下。

现象:

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

?

分析:

java程序启动后,默认(请注意是默认)会在/tmp/hsperfdata_userName目录下以该进程的id为文件名新建文件,并在该文件中存储jvm运行的相关信息,其中的userName为当前的用户名,/tmp/hsperfdata_userName目录会存放该用户所有已经启动的java进程信息。对于windows机器/tmp用Windows存放临时文件目录代替。

?

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

?

原因:

(1)、磁盘读写、目录权限问题

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

?

(2)、临时文件丢失,被删除或是定期清理

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

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

?

(3)、java进程信息文件存储地址被设置,不在/tmp目录下

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

?

关于设置该文件位置的参数为-Djava.io.tmpdir

?

其他:

/tmp/hsperfdata_userName/pid文件会在对应java进程退出后被清除。如果java进程非正常退出(如kill -9),那么pid文件会被保留,直到执行一次java命令或是加载了jvm程序的命令(如jps、javac、jstat),会将所有无用的pid文件都清除掉

?

关于jps更多的介绍,查看oracle介绍?http://download.oracle.com/javase/1.5.0/docs/tooldocs/share/jps.html


?

It turns out that tha vast majority of these system calls are not for GC and not for JIT compilation - they're to wake up a thread that is for gathering statistics about the VM, which are written to a temporary directory with a name such as /tmp/hsperfdata_${USER}/${PID}, and which can be explored using the jstat tool.

https://forums.oracle.com/forums/thread.jspa?threadID=1174213
If the output is empty please verify that you have readwrite access in the directory /tmp/hsperfdata_<loginname> which is where the JVM storesall the jvmstat information for a given java process.


https://forums.oracle.com/forums/thread.jspa?threadID=2151967 5 楼 fuyou001 2011-11-29   我进入/tmp/hsperfdata_userName 目录,什么都没有,但没看了crontab 没发现有清空的任务,这是什么原因导致没有的呢 6 楼 bloodwolf_china 2012-08-07   /tmp/hsperfdata_userName 目录有读写权限,目录下什么都没有
crontab 没发现有清空的任务
设置-Djava.io.tmpdir变量,但是tomcat默认启动都会设置,测试环境jps没问题,现网有问题 7 楼 Trinea 2012-08-21   bloodwolf_china 写道/tmp/hsperfdata_userName 目录有读写权限,目录下什么都没有
crontab 没发现有清空的任务
设置-Djava.io.tmpdir变量,但是tomcat默认启动都会设置,测试环境jps没问题,现网有问题
可以问下你们公司线网机器的管理员是否做了处理,或是其他java应用是否有这种问题,必须是应用对该目录有读写权限而不是机器账户

热点排行