在日常工作中,我们经常查看Java的Thread Dump, HeapDump,但都要登录到对应的服务器上去操作,很是麻烦。
那有没有在本机就可以遥控完成这些事情呢?请看下文实战。
远程jstat
Step by Step
1、 在机器上启动jstatd,一个daemon进程,更多解释见此链接
1.1、 首先需要准备一个java.policy文件,保存到如/home/admin/jstatd.java.policy
grant codebase "file:${java.home}/../lib/tools.jar" { permission java.security.AllPermission; }; |
1.2、 启动jstatd
jstatd -J-Djava.security.policy=/home/admin/jstatd.java.policy -J-Djava.rmi.server.logCalls=true |
1.3、 同时需要执行一个命令看看(linux需要)
Hostname –i 如果显示是127.0.0.1,则需要修改/etc/hosts文件,去掉对本机名的配置,让本机名解析到它的IP地址,如10.20.131.214 |
2、 做完步骤1,那可以说是万事具备了,很多问题都解决了,接下来在本地先看看远程机器上启动了多少个java进程
可以看到这台机器上启动了两个java程序,一个是第一步我们启动的jstatd,另一个为jboss进程。
3、 看看heap的使用情况吧
参考:
- jps - the Java Process Status Application
- jstat - the Java Virtual Machine Statistics Monitoring Tool
- jstatd - the jvmstat daemon
远程Thread Dump
1、 同上,需要在被dump的机器上启动jsadebugd(Debugger)
jsadebugd 31042 //31042为jps看到的pid,对应jboss的进程ID |
2、 在客户机上(需要linux系统,widnows的jdk无此功能)
jstack marketdev8 //可以为机器名或IP |
注意:本地和服务器上的jdk版本号必须一样。
参考:
使用命令行太麻烦?那就对了,试试sun提供的VisualVM,jdk1.6自带了,可以到bin目录下找到它。
什么也不说了,直接运行此exe,打开界面如下:
(图1)
(上图1左边的数可以看到,VisualVM分为3类,Local它会自动侦测到,并显示出来)
双击Local下的任一节点,看到右边的变化(有点像JProfiler)
(图2)
看看Visual GC的界面(Java Heap的使用,一目了然)
(图3)
再在左边的树形窗口,右键看看(看到了Thread Dump, Heap Dump)
(图4)
做Thread Dump很快,马上就可以看到结果
(图5)
Heap Dump要稍花费一些时间(可以看到当前heap里对象的数量及占用的比例,做OOM很好用)
(图6)
双击每一行,可以看到具体的信息
(图7)
我们再看一下图1,左边的窗口中,第二个节点—Remote,它可以用来操作远程机器。远程机器需要启动一个daemon:jstatd
1、远程机器启动jstatd
1.1、 首先需要准备一个java.policy文件,保存到如/home/admin/jstatd.java.policy
grant codebase "file:${java.home}/../lib/tools.jar" { permission java.security.AllPermission; }; |
1.2、 启动jstatd
jstatd -J-Djava.security.policy=/home/admin/jstatd.java.policy -J-Djava.rmi.server.logCalls=true |
1.3、 同时需要执行一个命令看看(linux需要)
Hostname –i 如果显示是127.0.0.1,则需要修改/etc/hosts文件,去掉对本机名的配置,让本机名解析到它的IP地址,如10.20.131.214 |
2、连接远程机器
(图8)
3、点击OK,看到会连接到远程机器,并显示出它下面的java进程。
(图9)
4、 这个时候的操作,就和上面Local的描述操作一样了。
最后,要注意的地方:
最好使用jdk1.6以上版本,不然visualVM很多功能不能用。
你自己也可以写一个VisualVM插件(基于NetBeans的插件体系),完成特殊的任务。