发布于 2017-04-13 15:39:15 | 358 次阅读 | 评论: 0 | 来源: PHPERZ

这里有新鲜出炉的Java并发编程示例,程序狗速度看过来!

Java程序设计语言

java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由Sun Microsystems公司于1995年5月推出的Java程序设计语言和Java平台(即JavaEE(j2ee), JavaME(j2me), JavaSE(j2se))的总称。


今日对线上tomcat做jstack时发现如下异常

Unable to open socket file: target process not responding or HotSpot VM not loaded

后来尝试不同的jdk版本发现tomcat在1.6.24版本以下的jmap,jstack都无法操作,而在1.6.18版本可以执行jmap,jstack.

原因分析

jvm运行时会生成一个目录hsperfdata_$USER($USER是启动java进程的用户),在linux中默认是/tmp,目录下会有些pid文件,存放jvm进程信息,而jmap,jstack等工具会读取/tmp/hsperfdata_$USER下的pid文件获取连接信息.
知道这个原因后,我马上检查了/tmp/hsperfdata_root目录,果然没有pid对应的文件,但在$TOMCAT_HOME目录中的temp目录中有对应的文件.

解决方案

通过google与实验,发现以下三种方式均可解决问题

从报错信息中我们可以看到,由于java进程的pid文件删除了,所以工具找不到对应的文件,但为什么会被删除呢?这是由于linux操作系统为了防止/tmp目录文件过多,有个删除管理机制tmpwatch,我们查看这个文件

vim /etc/cron.daily/tmpwatch
flags=-umc
/usr/sbin/tmpwatch "$flags" -x /tmp/.X11-unix -x /tmp/.XIM-unix \
    -x /tmp/.font-unix -x /tmp/.ICE-unix -x /tmp/.Test-unix \
    -X '/tmp/hsperfdata_*' 30d /tmp
/usr/sbin/tmpwatch "$flags" 720 /var/tmp
for d in /var/{cache/man,catman}/{cat?,X11R6/cat?,local/cat?}; do
    if [ -d "$d" ]; then
    /usr/sbin/tmpwatch "$flags" -f 720 "$d"
    fi
done

这里第四行是新增的,表示系统每天会用tmpwatch命令检查并删除/tmp下超过30天未访问的文件和目录.

修改tomcat的Djava.io.tmpdir参数,统一使用/tmp目录,修改catalina.sh添加CATALINA_TMPDIR=/tmp即可.

最后一种就是升级至java 6 update 25,但java 7是否有此问题并没有验证,毕竟开发与生产环境都是java 6,有兴趣的朋友可以尝试后给我留言.



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务