推荐一款好用的JAVA IO分析工具JPicus

去年用过一个很好用的工具,一直没有记录下来,现在分享给大家。这个工具的用途就是,可以查看,Java process都打开了那些文件,是由哪个thread打开的。

我碰到的问题是这样的,jboss使用log4j做日志系统,有个功能叫file rolling,作用是按照时间或者按照规定文件大小自动备份旧的日志,然后创建新的日志。前一阵子遇到一个问题,jboss的log文件rolling发生了异常,备份文件没有生成。查看了一下log4j的code,rolling时的做法是将旧的logfile重命名。初步分析原因是有其他的线程打开日志文件,导致文件重命名失败。使用process explorer查看, 发现jboss的java process持有多个server.log的文件句柄,证实了我的猜想。但是问题是无法判断出究竟是哪里的code打开了server.log. 经过google找到了一个非常好用的java io 分析工具JPicus. JPicus分为server和client两部分. server part 使用java的instrument技术实现,可以收集java进程中对文件的使用情况。client part是一个eclipse的插件。使用方法类似一般JvisualVM 之类的profiler, 打开一个connection 到jvm, 然后take 一个snapshot. 就可以获取java process持有的每一个文件句柄的信息。可以看到是哪一个线程打开了该句柄,以及该线程的call stack. 这样问题就一目了然了。具体的使用方法比较简单大家可以参考JPicus网站上的教程,我这里就不赘述了。下面贴一个运行起来的UI截图:

推荐一款好用的JAVA IO分析工具JPicus_第1张图片

 

安装时遇到了一些麻烦,下面是一些提醒:

1. JPicus对eclipse版本有要求,我用的3.6.1使用正常,同事用3.2遇到了一些问题。

2. JPicus网站上的client端安装链接有点问题,在eclipse中直接输入那个链接无法进行安装。我刚才又去download页面试了一下,现在连download agent jar的页面都打不开了,也不知道是被盾了,还是挂掉了。所幸的都是我之前download的jar还留着。agent jar , UI plug-in. 本来你应该直接从JPicus的update站点安装客户端的,但是现在JPicus的update站点有问题。我们可以通过自建一个update站点来解决这个问题。使用任意的web server(我用的IIS)把UI plug-in那个zip解压到你站点下的某一个目录下就可以了。在eclipse中选help->install new software->add repository 添加你的update站点的url就可以安装了,贴个图。

 
推荐一款好用的JAVA IO分析工具JPicus_第2张图片
 

一点抱怨:

国内对SAP的develper network访问非常不好,总有莫名奇妙的问题。这个很好的工具也没有广泛的流传开,安装起来费很大力气。不知道有没有功能类似的开源工具呢,如果有的话,我一定会迅速抛弃JPicus的。

 

 

 

你可能感兴趣的:(java,IO,debug,JPicus)