jconsole监控远程weblogic和tomcat

    jconsole可以对远程主机上的java进程的内存使用情况进行监控。本文将讲解如何使用jconsole监控远程主机上的weblogic和tomcat。

    一、环境

    1、本机环境:windows xp+jconsole(jdk1.6)

    2、远程环境1:sunos(solaris、jdk1.6)+weblogic

    3、远程环境2:redhat(jdk1.6)+tomcat

    本文将介绍两种环境下的配置,两者配置基本上一样,其他的系统应该也差不多。

    二、远程连接sunos(solaris)+weblogic

    1、jconsole使用jmx进行监控,需要在应用启动时,配置启动参数。因为使用的是weblogic服务器,故需要在${DOMAIN_HOME}/bin/setDomainEnv.sh环境中进行配置。

JAVA_OPTIONS="${JAVA_OPTIONS} -Dcom.sun.management.jmxremote.port=9000"
JAVA_OPTIONS="${JAVA_OPTIONS} -Dcom.sun.management.jmxremote.authenticate=false"
JAVA_OPTIONS="${JAVA_OPTIONS} -Dcom.sun.management.jmxremote.ssl=false"
    2、查看/etc/hosts,默认情况下,已经将hostname对应到ip上了,故此处不需要进行调整。

::1          localhost
127.0.0.1    localhost
10.1.97.20   c20 c20.sinosure.com.cn loghost

    3、将${JAVA_HOME}/jre/lib/management目录属性进行修改

chmod -R 777 ./management

    4、启动weblogic,并在本地开启jconsole进行远程连接,选择“远程进程”,输入主机IP和端口号。

    点击“连接”,显示监控界面:

    注意:在启动和关闭weblogic时,都会调用setDomainEnv.sh脚本。如果配置完成并且启动weblogic后,再关闭weblogic时,会提示端口号已被占用,此问题是因为启动和关闭weblogic时,都会启动对该端口号的监听程序。可以考虑在setDomainEnv.sh中增加一个判断,只有在启动weblogic时,才启动对该端口号的监听。

    三、远程连接redhat+tomcat

    1、同上一节第一步,不同的是,tomcat在启动时,设置参数的文件时catalina.sh,因此参数需在此设置。

JAVA_OPTS="$JAVA_OPTS -Djava.rmi.server.hostname=192.168.1.110""
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.port=9000"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false"
      

    2、对于redhat,默认情况下,hostname没有对应到ip。在redhat上,可使用hostname -i查看,如果显示的是127.0.0.1,那就需要配置/etc/hosts。

#127.0.0.1              localhost.localdomain localhost
192.168.1.110           localhost.localdomain localhost

    注意:将127.0.0.1那一行注释,然后将hostname对应到192.168.1.110。

    3、配置${JAVA_HOME}/jre/lib/management目录下的文件。

cp jmxremote.password.template jmxremote.password

    将注释掉的内容还原:

monitorRole  QED
controlRole   R&D

    执行命令,修改文件属性:

chmod 600 jmxremote.access
chmod 600 jmxremote.password

    4、可参考上一节的第四步。

    注意:在启动和关闭tomcat时,都会调用catalina.sh脚本。如果配置完成并且启动tomcat后,再关闭tomcat时,会提示端口号已被占用,此问题是因为启动和关闭tomcat时,都会启动对该端口号的监听程序。可以考虑只有在启动tomcat时,通过判断参数为start时,才启动对该端口号的监听。

    通过以上的配置,可以看出在sunos系统和redhat系统上的配置不完全一致,同样在tomcat中的配置也不完全一致,需要注意差异。

   四、校验及异常处理

    1、启动后,系统会启动对配置端口的监听,可通过命令查看是否正常启动:

netstat -an | grep 9000

    如果有在监听,说明启动正常。

    2、在启动jconsole后,提示连接不上,但是在远程主机上发现该端口已经被连接上(可通过netstat -an查看)。
    检查配置是否有误;或者查看防火墙是否关闭。






郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。