2013-03-01 163 views
1

我想使用JMX通过远程连接监视tomcat和ActiveMQ。Tomcat 7.0.33 JAVA_OPTS配置

对于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我可以连接到网址:

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 

然后,当我试图连接到url service:jmx:rmi:///jndi/rmi://x.x.x.x:9004/jmxrmi在Jconsole中,连接失败。 我试着使用Netbeans(谁似乎使用catalina.bat中,而不是的startup.bat),并从移动的startup.bat的JAVA_OPTS到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,我仍然可以连接到它。我真的不知道哪里出了问题......如果有人能帮助我

+0

我解决了这个问题'...未识别为内部或外部添加command''设置CATALINA_OPTS ='无报价每个参数之前。所以Tomcat似乎正常启动,但我仍然无法访问'service:jmx:rmi:/// jndi/rmi://x.x.x.x:9004/jmxrmi' – AxelF 2013-03-01 14:20:54

回答

2

我终于解决了这个问题,现在可以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为第一个参数,全部只在一个CATALINA_OPTS声明中。

希望它可以是有用的