图片 4

配置远程JConsole

要通过JMX远程监控Tomcat,首先需要进行Tomcat的JMX远程配置。

# monitorRole QED

 

 

set JMX_REMOTE_CONFIG=-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false  
set CATALINA_OPTS=%CATALINA_OPTS% %JMX_REMOTE_CONFIG% 

如果是JBOSS,还需加这一行
JAVA_OPTS=”$JAVA_OPTS
-Djava.rmi.server.hostname=10.0.122.132″,如果不加就连不上

set JMX_REMOTE_CONFIG=-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=true -Dcom.sun.management.jmxremote.password.file=../conf/jmxremote.password -Dcom.sun.management.jmxremote.access.file=../conf/jmxremote.access  
set CATALINA_OPTS=%CATALINA_OPTS% %JMX_REMOTE_CONFIG%

用户名及密码(参考jmxremote.password文件)
monitorRole只能读,controlRole能读写

先修改Tomcat的启动脚本,windows下为bin/catalina.bat(linux下为catalina.sh),添加以下内容:

JDK自带工具JCONSOLE,可以以图形界面远程监控JVM的情况,也可作相应的一些操作。

复制并修改授权文件

JAVA_HOME/jre/lib/management下有jmxremote.access和jmxremote.password.template的模板文件,将两个文件复制到CATALINA_BASE/conf目录下
*重命名jmxremote.password.template文件为jmxremote.password

*修改CATALINA_BASE/conf/jmxremote.access 添加内容:
     monitorRole readonly
     controlRole readwrite
*修改CATALINA_BASE/conf/jmxremote.password 添加内容:
    monitorRole  liuke  #可自定义
    controlRole   liuke  #可自定义

JAVA_OPTS=”-Xmx1024M -Xms512M -Xss3M”

使用jconsole或jvisualvm测试JMX

运行JAVA_HOME/bin目录下的jconsole或jvisualvm,打开控制台,然后建立连接,填写地址、端口号、用户名、口令即可连接。

图片 1图片 2

图片 3

 

4、查看JMX启动情况

图片 4

chmod 600 jmxremote.access

linux为
JAVA_OPTS=-Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false

-Dcom.sun.management.jmxremote.port=8999,是jmxremote使用的端口号,可修改。
-Dcom.sun.management.jmxremote.authenticate=false,表示不需要鉴权,主机+端口号即可监控。

1、修改Tomcat的启动语句,将bin/catalina.sh文件vi编辑:

注意:此配置添加在catalina.bat文件开头的注释行(rem或#)后面即可。

 

 

 

本文使用的tomcat版本为7.0.77。

a、将jmxremote.access、jmxremote.password.template权限调整为读写;

需要鉴权的配置:

mv jmxremote.password.template jmxremote.password

不需鉴权的配置:

url:远程主机IP:9999

调整为

检查LINUX环境:
运行:hostname
-i,如果返回127.0.0.1,则要改/etc/sysconfig/network里的HOSTNAME为NEWHOST,再在/etc/hosts里增加一行本机IP对应NEWHOST的值。
清除防火墙的所有东西:iptables -F!!
参考:http://dikar.iteye.com/blog/534109

将原

b、jmxremote.password.template文件重命名

export JAVA_OPTS

:wq 保存操作

netstat -a | grep -i 9999 查看端口占有情况

使用JMX方式,输入url 用户名(controlRole)、密码(R&D)即可访问

export JAVA_OPTS

# controlRole R&D

chmod 600 jmxremote.password.template

目录切换至JAVA_HOME所在目录

3、启动Tomcat

5、客户端机器可通过jconsole或visualvm对其进行监控

/jre/lib/management下,

本文永久更新链接地址http://www.linuxidc.com/Linux/2015-02/113415.htm

c、vi jmxremote.password

如机器9999端口被其他程序占用,可调整端口-Dcom.sun.management.jmxremote.port=????

的#号(Solaris下可编辑模式下,可以使用x删除光标标记处字符)

./catalina.sh run

JAVA_OPTS=”-Xmx1024M -Xms512M -Xss3M
-Dcom.sun.management.jmxremote.port=9999
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=true”

配置中的安全原因出错,由于密码是以明文的方式保存在:jmxremote.password中,所以对此文件只能有所有者都读取,其他人都不能读取。Windows下的设置情况见:http://www.linuxidc.com/Linux/2015-02/113416.htm

图片 5

2、修改jmx配置文件

去掉