【问题标题】:Creating an RMI Connector Client创建 RMI 连接器客户端
【发布时间】:2013-04-26 04:55:05
【问题描述】:

我正在尝试连接到 MBean 服务器。我需要编写 JMX 客户端应用程序。这是用于客户端应用程序的代码。但我有一个与此相关的异常

无法检索 RMIServer 存根: javax.naming.ServiceUnavailableException [根异常是 java.rmi.ConnectException:连接拒绝主机:localhost; 嵌套异常是:

谁能帮我解决这个问题。

import java.io.IOException;
import javax.management.MBeanServerConnection;
import javax.management.MBeanServerInvocationHandler;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;


public class SystemConfigClient {

    public static final String HOST = "localhost";
    public static final String PORT = "1099";


    public static void main(String[] args) throws IOException, MalformedObjectNameException {
        JMXServiceURL url =new JMXServiceURL("service:jmx:rmi:///jndi/rmi://" + HOST + ":" +PORT+ "/jmxrmi");

        JMXConnector jmxConnector = JMXConnectorFactory.connect(url);
        MBeanServerConnection mbeanServerConnection = jmxConnector.getMBeanServerConnection();
        //ObjectName should be same as your MBean name
        ObjectName mbeanName = new ObjectName("ifs.demo1.jmx:type=SystemConfig");

        //Get MBean proxy instance that will be used to make calls to registered MBean
        SystemConfigMBean mbeanProxy =
            (SystemConfigMBean) MBeanServerInvocationHandler.newProxyInstance(
                mbeanServerConnection, mbeanName, SystemConfigMBean.class, true);

        //let's make some calls to mbean through proxy and see the results.
        System.out.println("Current SystemConfig::" + mbeanProxy.doConfig());

        mbeanProxy.setSchemaName("NewSchema");
        mbeanProxy.setThreadCount(5);

        System.out.println("New SystemConfig::" + mbeanProxy.doConfig());

        //let's terminate the mbean by making thread count as 0
        mbeanProxy.setThreadCount(0);

        //close the connection
        jmxConnector.close();
    }

}

我已使用以下参数运行此代码。

Dcom.sun.management.jmxremote Dcom.sun.management.jmxremote.port=1099 Dcom.sun.management.jmxremote.authenticate=false dcom.sun.management.jmxremote.ssl=false

但我得到了例外

线程“main”java.io.IOException 中的异常:检索失败 RMIServer 存根:javax.naming.ServiceUnavailableException [根 例外是 java.rmi.ConnectException:连接拒绝主机: 本地主机;嵌套异常是:java.net.ConnectException: 连接被拒绝:连接]在 javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:338) 在 javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:248) 在 javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:207) 在 com.demo1.jmx.SystemConfigClient.main(SystemConfigClient.java:29) 引起:javax.naming.ServiceUnavailableException [根异常是 java.rmi.ConnectException:连接拒绝主机:localhost; 嵌套异常是:java.net.ConnectException:连接被拒绝: 连接]在 com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:101) 在 com.sun.jndi.toolkit.url.GenericURLContext.lookup(GenericURLContext.java:185) 在 javax.naming.InitialContext.lookup(InitialContext.java:392) 在 javax.management.remote.rmi.RMIConnector.findRMIServerJNDI(RMIConnector.java:1886) 在 javax.management.remote.rmi.RMIConnector.findRMIServer(RMIConnector.java:1856) 在 javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:257) ... 3 更多原因:java.rmi.ConnectException:连接被拒绝 主机:本地主机;嵌套异常是:java.net.ConnectException: 连接被拒绝:连接在 sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:601) 在 sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:198) 在 sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:184) 在 sun.rmi.server.UnicastRef.newCall(UnicastRef.java:322) 在 sun.rmi.registry.RegistryImpl_Stub.lookup(未知来源)在 com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:97) ... 8 更多原因:java.net.ConnectException:连接被拒绝: 在 java.net.PlainSocketImpl.socketConnect(Native Method) 处连接 java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333) 在 java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195) 在 java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182) 在 java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366) 在 java.net.Socket.connect(Socket.java:529) 在 java.net.Socket.connect(Socket.java:478) 在 java.net.Socket.(Socket.java:375) 在 java.net.Socket.(Socket.java:189) 在 sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:22) 在 sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:128) 在 sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:595) ... 13 个 Java 结果:1

【问题讨论】:

    标签: java jboss rmi mbeans


    【解决方案1】:

    您是否注意到您使用带有“D”而不是“-D”的 VM 参数?或者它只是一个错字? 正确的是:

    -Dcom.sun.management.jmxremote 
    -Dcom.sun.management.jmxremote.port=1099 
    -Dcom.sun.management.jmxremote.authenticate=false 
    -Dcom.sun.management.jmxremote.ssl=false
    

    【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-02-28
    • 2014-07-04
    • 1970-01-01
    • 2012-03-05
    • 2013-11-08
    • 1970-01-01
    相关资源
    最近更新 更多