用VisualVM和JConsole监控tomcat性能 --没测试
source:http://www.cnblogs.com/testgirl/archive/2010/01/07/1641208.html最近要做性能测试,除了要测试系统能支撑用户并发数,还要统计应用的对CPU,内存使用情况。要测试的系统基于Java开发,因此试着用VisualVM来监控。VisualVM除了能监控CPU和内存使用情况,还能监控和分析垃圾回收和线程,当然这是更高级了,开发人员用的更多一点。JConsole是VisualVM的前身,VisualVM已经内置在JDK1.6里面了,如果安装的JDK里面没有,也可以去sun的网站去单独下载JConsole和VisualVM。
我的测试环境是Solaris和tomcat,不同环境配置可能配置有差异。
1、修改Tomcat的启动语句,将bin/catalina.sh文件vi编辑:
将原
JAVA_OPTS="-Xmx1024M -Xms512M -Xss3M"
export JAVA_OPTS
调整为
JAVA_OPTS="-Xmx1024M -Xms512M -Xss3M -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=true"
export JAVA_OPTS
2、修改jmx配置文件
目录切换至JAVA_HOME所在目录
/jre/lib/management下,
a、将jmxremote.access、jmxremote.password.template权限调整为读写;
chmod 600 jmxremote.password.template chmod 600 jmxremote.access
b、jmxremote.password.template文件重命名
mv jmxremote.password.template jmxremote.password
c、vi jmxremote.password
去掉
# monitorRole QED
# controlRole R&D
的#号(Solaris下可编辑模式下,可以使用x删除光标标记处字符)
:wq 保存操作
3、启动Tomcat
./catalina.sh run
4、查看JMX启动情况
netstat -a | grep -i 8999 查看端口占有情况
如机器8999端口被其他程序占用,可调整端口-Dcom.sun.management.jmxremote.port=????
5、客户端机器可通过jconsole或visualvm对其进行监控
使用JMX方式,输入url 用户名、密码即可访问
url:远程主机IP:8999
用户名及密码(参考jmxremote.password文件) monitorRole只能读,controlRole能读写
页:
[1]