使用JMX透过防火墙远程监控tomcat服务

本文介绍如何使用JMX远程监控防火墙后的Linux上的Tomcat服务。通过配置catalina-jmx-remote.jar、server.xml及防火墙等步骤,实现jvisualvm或jconsole工具的远程监控。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用JMX透过防火墙远程监控tomcat服务

JDK的bin目录下有jvisualvm或jconsole可以监控本地和远程jvm实例的运行动态(包括cpu,内存等), 对于性能分析或内存泄露分析等极其方便。下面介绍如何通过这两个工具远程监控有防火墙的linux上的tomcat服务。 废话少说,直接上正题:

我的测试环境是:centos 6.2(IP为192.168.1.118)上通过jsvc将tomcat 7作为服务启动。

  • 下载http://mirror.bjtu.edu.cn/apache/tomcat/tomcat-7/v7.0.28/bin/extras/catalina-jmx-remote.jar并放在tomcat7的$CATALINA_BASE/lib目录。

  • 修改tomcat7的$CATALINA_BASE/conf/server.xml,在 下加入监听器:

    <Listener className="org.apache.catalina.mbeans.JmxRemoteLifecycleListener"
      rmiRegistryPortPlatform="10001" rmiServerPortPlatform="10002" />
    
  • 建立文本文件$CATALINA_BASE/conf/jmxremote.password,其内容为:admin letmein

  • 建立文本文件$CATALINA_BASE/conf/jmxremote.access,其内容为:admin readwrite

  • 修改jsvc的服务启动配置文件,加入启动参数,如:

    CATALINA_OPTS="$CATALINA_OPTS -Xms128m -Xmx200m -XX:PermSize=64M -XX:MaxPermSize=256m -XX:+UseConcMarkSweepGC \
    -Djava.rmi.server.hostname=192.168.1.118 \
    -Dcom.sun.management.jmxremote.password.file=$CATALINA_BASE/conf/jmxremote.password \
    -Dcom.sun.management.jmxremote.access.file=$CATALINA_BASE/conf/jmxremote.access \
    -Dcom.sun.management.jmxremote.ssl=false"
    
  • 开通linux防火墙的端口:10001和10002.(例如:在/etc/sysconfig/iptables中加入

    -A INPUT -m state --state NEW -m tcp -p tcp --dport 10001 -j ACCEPT
    -A INPUT -m state --state NEW -m tcp -p tcp --dport 10002 -j ACCEPT),
    

    注意要重启防火墙使生效。

  • 至此远程可以使用jvisualvm或jconsole通过地址:(192.168.1.118:10001或者service:jmx:rmi:///jndi/rmi://192.168.1.118:10001/jmxrmi),使用用户admin密码letmein登录 动态监控tomcat服务了.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值