JConsole监控远程Tomcat服务器

为了解决内存溢出的问题,会用到一些监视内存的工具,jconsole这个工具在jdk1.6自带了
这个工具可以查看系统的 堆,非堆,线程,等等的一些整体的情况,从而可以判断出系统的一个大概的性能情况。
startup.sh来设置

JAVA_OPTS='-Djava.rmi.server.hostname=192.168.1.110 \
-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8081 \
-Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false'

特别注意:
1. 如果你的linux系统下hostname -i显示为127.0.0.1,则jconsole将连接不上远程服务器
方法一可以修改/etc/hosts文件,将其第一行的”127.0.0.1 localhost.localdomain localhost”,修改为:”192.168.1.110 localhost.localdomain localhost”,其中,”192.168.1.110″为实际的服务器的IP地址。hosename -i输出结果为192.168.1.110,JConsole图形界面才能显示出来,但是用此方法可能会有问题,如sendmail;
推荐使用方法二,在JAVA_OPTS加上’-Djava.rmi.server.hostname=192.168.1.110′

2. -Dcom.sun.management.jmxremote.port=8081,这个端点是jconsole专用的,不要和你的系统的端口冲突。再启动你的应用。

3. 看了网上很多文章都是在catalina.sh文件中加JAVA_OPTS,这样是有问题的,关闭tomcat会报该端口已经被占用,因为关闭 tomcat时候,还会读取catalina.sh,所有最好在startup.sh文件中添加JAVA_OPTS那一段。

4. 最后双击本机jdk1.6/bin/jconsole.exe,启动Jconsole监控界面,在远程连接处输入:192.168.1.110:8081,输入Linux主机的用户名和密码,连接即可,-Dcom.sun.management.jmxremote.authenticate=false,设置成了false,所以如果不知道Linux机器的用户名和密码,也可以不输入,直接连接。
如果将-Dcom.sun.management.jmxremote.authenticate=ture,配置方法如下:

cd /usr/java/jdk1.7.0_71/jre/lib/management
cp jmxremote.password.template jmxremote.password   
chmod 600 jmxremote.access jmxremote.password 

jmxremote.access 一般保持原始内容不变即可。

对于jmxremote.password,将其中的:
monitorRole  linuxeye
controlRole  linuxeye
井号注释取消掉。其中monitorRole为只拥有只读权限的角色,controlRole有更高权限:读写等等。

最后将端口加入防火墙信任列表

iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 8081 -j ACCEPT
iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 57062 -j ACCEPT

重启tomcat
在上面配置的jmx代理就会随tomcat一起启动。
将会启动2个端口8081、57062

可以使用netstat -an | grep -E ‘8081|57062’命令查看端口是否正常启动。
打开windows java安装路径Java\jdk1.7.0_71\bin、jconsole.exe,输入服务器端相关信息:

JConsole监控远程Tomcat服务器_第1张图片

点击”连接”,进入监控页面:

JConsole监控远程Tomcat服务器_第2张图片

原文:https://blog.linuxeye.com/262.html

你可能感兴趣的:(JConsole监控远程Tomcat服务器)