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
文章引自:http://trinea.iteye.com/blog/1196400
最新文章
- Xenu Link Sleuth-简单使用
- Atitit RSA非对称加密原理与解决方案
- onfiguration problem: Unable to locate Spring NamespaceHandler for XML schema namespace [http://www.springframework.org/schema/security]
- 内存单元按字节编址,地址0000A000H~0000BFFFH共有几个存储单元
- 网络子系统54_ip协议分片重组_定位ipq
- sql 联合查询速度慢,需要对其进行分组
- MyEclipse+Tomcat开发Web项目时修改内容不能及时显示问题解决方法
- spring事务详解
- 源码剖析Django REST framework的请求生命周期
- oracle 安装介绍
- No input file specified. phpStudy nginx报错解决方案
- spring BeanPostProcessor
- Webapi创建和使用 以及填坑(三)
- iptables防火墙详解(三)
- Testing - 软件测试知识梳理 - 测试用例
- 剑指offer:变态跳台阶
- vue中使用base64和md5
- getopts的使用方法
- java reflect反射获取方法变量参数
- BZOJ3787:Gty的文艺妹子序列(分块,树状数组)
热门文章
- 第二十二篇:Spring简单定时任务
- 19.SimLogin_case05
- Java中关于注释、标识符、变量、常量、数据类型、类型转换、转移字符以及数值型的表现形式的详解
- csp-s模拟测试10.1(b)X 国的军队,排列组合, 回文题解
- 在自己的工程中使用开源界面库Duilib
- BZOJ 3245 最快路线
- Consul 集群搭建
- PAT甲级——A1004 Counting Leaves
- PAT甲级——A1002 A+B for Polynomials
- topology进程结束会不会关闭数据库连接