jstat pid not found

(1)【一个小问题】jstat PID not found产生的原因

声 明:我的文章都是在实际工作中遇到并解决问题后撰写的,可能你早就一清二楚了,也可能对你没有任何帮助,喜欢就请顶一下,不喜也请勿喷。就像足球一样, 不喜欢中国足球的就请不要关注,你可以去看乒乓球、羽毛球,甚至,冰壶!但不要去骂他们,毕竟还有很多人痴心地喜欢国足,我就是其中之一。

 

我今天遇到了一个小问题,我想用jstat命令查看tomcat进程(PID=14472)的内存使用情况,命令如下:jstat -gcutil 14472。 然后就报错了,错误提示信息为 14472 not found。用 jps命令 查看java进程ID,居然没有输出结果。但确信java进程是存在的,用 ps -ef | grep java 能看到java进程。

 

百度了下,找到了这篇文章,http://dikar.iteye.com/blog/781083 ,看完后问题就解决了,记录下来,以便日后使用。

 

原来,java进程把jvm perfdata存到了 /tmp/hsperfdata_{USER}/{PID} 文件里,我用的是ramos用户启动的tomcat,pid为14472,所以就会生成这个文件:/tmp/hsperfdata_ramos /14472 。而之前,我做过一个修改,导致ramos用户没有文件夹/tmp/hsperfdata_ramos的写权限,所以导致出现了此问题。

 

最后我用root用户登录,索性把/tmp/hsperfdata_ramos文件夹删除,然后再切换到ramos用户下,重启tomcat,让它重建/tmp/hsperfdata_ramos文件夹,问题解决!

(2)[原]jstat pid not found

2012-5-10阅读1503 评论1

今日想利用jdk自带工具jstat命令查看gc情况。无奈使用时报进程找不到错误。痛苦万分……在网上找了许多资料,最终解决。

首先,说一下jstat大致的工作原理(下面的jvmstat应该是早期jdk里面的名称,后来改称jstat):

       使用jvmstat命令会生成一个目录文件叫hsperfdata_username,那这个目录文件在哪里呢,默认的是生成在java.io.tmpdir目录下,java.io.tmpdir在linux下默认是/tmp下,故默认开启了jvm monitor的功能以后就会在/tmp目录下生成一个目录,hsperfdata_username,然后这个目录中会有一个pid文件,可以利用strings查看里面的文件内容,一般就是jvm的进程信息而已。

         再看我遇到的情况,运行jstat命令后,发现/tmp目录下确实生成了hsperfdata_username文件夹,但是hsperfdata_username文件夹下面没有进程ID的文件夹。再搜索资料发现问题如下,jdk1.6.0.23/24版本兼容性问题,我整好使用的是24版本,哭杯具。

While it's true that 6u23/24 introduce this issue, it's not a bug in jps. Rather a change in behavior of the VM itself. On GNU/Linux Jps and the likes seem to only look at /tmp but not necessarily your CATALINA_TMPDIR. If set or not, try to export CATALINA_TMPDIR=/tmp which translates to "-Djava.io.tmpdir=/tmp" and after restarting the Tomcat process you should see Tomcat's data as "/tmp/hsperfdata_/" and Jps will most likely work again as well.

      说了这么多,最后我们说说解决办法,按照上面说的不是jdk的bug,只需要修改VM的配置文件就ok.那好我们用vi打开tomcat的catalina.sh文件,并找到CATALINA_TMPDIR的说明和配置的地方。

#   CATALINA_TMPDIR (Optional) Directory path location of temporary directory the JVM should use (java.io.tmpdir).  Defaults to  $CATALINA_BASE/temp.
可以看到他的默认路径是$CATALINA_BASE/temp。

我们修改如下,将默认配置路径注释掉,增加CATALINA_TMPDIR=/tmp这句。OK,重启tomcat就搞定了。

if [ -z "$CATALINA_TMPDIR" ] ; then
  # Define the java.io.tmpdir to use for Catalina
  # CATALINA_TMPDIR="$CATALINA_BASE"/temp
 CATALINA_TMPDIR=/tmp
fi
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值