其实在 JDK 5 中已经新加入了这个功能了. 现在的 JDK 已经内置了对 VM 的监控功能.
关于 JDK 5 中如何使用这个工具可以参考这里:
http://java.sun.com/developer/technicalArticles/J2SE/jconsole.html
http://java.sun.com/j2se/1.5.0/docs/guide/management/jconsole.html
JDK 5 和 JDK 6 中 JConsole的主要区别是:
JDK 5中 Java应用(JVM)启动时必须将 JMX注册到 MBeanServer中,JConsole才能监控到该JVM。
即Java应用启动时要加 -Dcom.sun.management.jmxremote 启动参数。
JDK 6中 JConsole可以从%TMP%/hsperfdata_user ( user 为当前登录用户名)目录下得到启动的JVM的信息。
因此Java应用启动时可以不用添加 -Dcom.sun.management.jmxremote 启动参数。
JDK 5使用JConsole的 如:
启动Tomcat
在catalina.bat中
echo Using CATALINA_BASE: %CATALINA_BASE% 前面加上下面一行
set JAVA_OPTS=%JAVA_OPTS%
-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port="9004"
-Dcom.sun.management.jmxremote.authenticate="false"
-Dcom.sun.management.jmxremote.ssl="false"
启动Eclipse中的Jboss
使用jconsole <pid>时,
I get the following error message: "<pid> is not a managed VM."
(另一种表现是:本地标签处没有显示任何可用PID),
表明没有开启一个JVM options。
解决方法(我的web是部署在Jboss中):
Eclipse中-->window-->Preference-->myeclipse-->Servers-->Jboss4-->JDK-->Optional JVM arguments
填写"-Dcom.sun.management.jmxremote",就可以了
JDK 6 中这个工具变的更加好用了.
jconsole 可以很方便的监控本机的所有 Java 应用和远程的应用.
监控本地应用
首先就是启动您要监控的应用, 例如我用 JDK 1.6 来启动了 Tomcat, 或者 Eclipse 也可以, 可以在任务管理器(Ctrl+Alt+Del可以调出来, 或者在任务栏点击右键)里看到进程ID, 例如我这里是 6132.
接着在 JDK 安装目录中(<JDK_HOME>/bin/jconsole.exe)启动 jconsole.exe (双击或者在 cmd 里面敲入 jconsole), 主界面会提示您建立一个新连接:
可以看到进程ID, 选择它, 然后点击"连接". 这些 ID 必须都是用 JDK 1.6 的 java.exe 启动的, 否则在列表里看不到.
JConsle 能监控内存,线程,类的数目和CPU然后点击各个 Tab 可以看到详细的输出, 详细的输出包括:
内存: 堆/非堆, 峰值, 内存的各个部分, 例如 Perm, Eden 等的大小曲线图.
线程: 峰值, 所有线程的列表, 堆栈跟踪(哪个对象中的线程)等. 还可以强制执行GC.
类: 峰值, 类总数曲线图.
MBean: 一些 JVM 参数的详细 MBean 信息.
监控远程进程
首先需要在运行的应用上启用远程管理, 参数如下(简单期间就不加用户验证了):
java -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -jar ../demo/jfc/Java2D/Java2Demo.jar
然后连接的时候选择远程进程, 地址输入:
localhost:1090
即可.当然在别的电脑上(一般是局域网)可以输入那个电脑的IP.
综述: 使用 JConsole 可以简单的监控 Server 状态, 但是本身要占一定的资源, 不过 JVM 自带的监控, 理论上讲应该是占资源很小很小的, 可以用它来方便的了解 Web 服务器应用进程的状态. 如果要调优应用, 还是使用 JProfiler 等工具更好一些, 当然它们占的资源也更大.
后记:
jdk1.6.0/demo/management/MemoryMonitor
这里带了个很好的画内存曲线图的例子... 大家改改就可以实现同时监控多台 Server 的内存曲线了....
2006.12.13