1

JMX を使用して、リモート接続で tomcat と ActiveMQ を監視したいと考えています。

activeMQ の場合、startup.bat の JAVA_OPTS にこれを追加しました。

JAVA_OPTS=
-Dwebconsole.type=properties \
-Dwebconsole.jms.url=tcp://localhost:61616 \
-Dwebconsole.jmx.url=service:jmx:rmi:///jndi/rmi://localhost:1099/ jmxrmi

Tomcat サーバーと ActiveMQ を起動すると、Jconsole で url に接続できます。

service:jmx:rmi:///jndi/rmi://x.x.x.x:1099/jmxrmi

Tomcat の監視用に追加しました:

-Dcom.sun.management.jmxremote ^
-Dcom.sun.management.jmxremote.port=9004 ^
-Dcom.sun.management.jmxremote.ssl=false ^
-Dcom.sun.management.jmxremote.authenticate=false ^
-Djava.rmi.server.hostname=x.x.x.x

service:jmx:rmi:///jndi/rmi://x.x.x.x:9004/jmxrmi次に、 Jconsole でURL に接続しようとすると、接続に失敗します。Netbeans (startup.bat ではなく catalina.bat を使用しているようです) を試し、java_opts を startup.bat から catalina.bat に移動しました。サーバーを起動したときのログは次のとおりです。

'-Dcom.sun.management.jmxremote' n'est pas reconnu en tant que commande interne
Using CATALINA_BASE:   "C:\Program Files\apache-tomcat-7.0.33"
Using CATALINA_HOME:   "C:\Program Files\apache-tomcat-7.0.33"
Using CATALINA_TMPDIR: "C:\Program Files\apache-tomcat-7.0.33\temp"
Using JRE_HOME:        "C:\Program Files\Java\jdk1.7.0_07"
Using CLASSPATH:       "C:\Program Files\apache-tomcat-7.0.33\bin\bootstrap.jar;C:\Program Files\apache-tomcat-7.0.33\bin\tomcat-juli.jar"
ou externe, un programme ex‚cutable ou un fichier de commandes.
'-Dcom.sun.management.jmxremote' n'est pas reconnu en tant que commande interne
ou externe, un programme ex‚cutable ou un fichier de commandes.

フランス語で申し訳ありませんが、重要な部分は、 -Dcom.sun.management.jmxremote が内部コマンドまたは外部コマンドとして認識されないことです。

Jconsole デバッグ出力:

java.io.IOException: Failed to retrieve RMIServer stub: javax.naming.ServiceUnavailableException [Root exception is java.rmi.ConnectException: Connection refused to host: 192.168.117.31; nested exception is: 
    java.net.ConnectException: Connection refused: connect]
    at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:357)
    at javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:267)
    at javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:226)
    at sun.tools.jconsole.ProxyClient.tryConnect(ProxyClient.java:354)
    at sun.tools.jconsole.ProxyClient.connect(ProxyClient.java:314)
    at sun.tools.jconsole.VMPanel$2.run(VMPanel.java:295)
Caused by: javax.naming.ServiceUnavailableException [Root exception is java.rmi.ConnectException: Connection refused to host: 192.168.117.31; nested exception is: 
    java.net.ConnectException: Connection refused: connect]
    at com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:118)
    at com.sun.jndi.toolkit.url.GenericURLContext.lookup(GenericURLContext.java:203)
    at javax.naming.InitialContext.lookup(InitialContext.java:411)
    at javax.management.remote.rmi.RMIConnector.findRMIServerJNDI(RMIConnector.java:1924)
    at javax.management.remote.rmi.RMIConnector.findRMIServer(RMIConnector.java:1891)
    at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:274)
    ... 5 more
Caused by: java.rmi.ConnectException: Connection refused to host: 192.168.117.31; nested exception is: 
    java.net.ConnectException: Connection refused: connect
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:619)
    at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:216)
    at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202)
    at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:340)
    at sun.rmi.registry.RegistryImpl_Stub.lookup(Unknown Source)
    at com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:114)
    ... 10 more
Caused by: java.net.ConnectException: Connection refused: connect
    at java.net.DualStackPlainSocketImpl.connect0(Native Method)
    at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:69)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339)
    at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
    at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:157)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:391)
    at java.net.Socket.connect(Socket.java:579)
    at java.net.Socket.connect(Socket.java:528)
    at java.net.Socket.<init>(Socket.java:425)
    at java.net.Socket.<init>(Socket.java:208)
    at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40)
    at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:146)
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613)
    ... 15 more

activeMQ 部分を startup.bat に残しましたが、まだ接続できます。どこに問題があるのか​​ 本当にわかりません...誰かが私を助けることができれば

4

1 に答える 1

3

最終的に問題を解決し、jConsole をポート 9004 に接続できるようになりました。catalina.bat の構成方法は次のとおりです。

set CATALINA_OPTS=-Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.port=9004 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=x.x.x.x

「入力」なし、引用符なしtrue、最初のパラメーターに指定し、すべて 1 つの CATALINA_OPTS 宣言のみで指定しました。

それが役に立つことを願っています

于 2013-03-05T09:21:31.603 に答える