最近使用jmx遇到一个问题,client/server同在一台机器上,jmx client能够成功连接server
如果把server移植到另一台机器上10.1.60.14,抛出如下异常:
java.net.ConnectException: Connection refused: connect
java.rmi.ConnectException: Connection refused to host: 127.0.0.1; nested exception is:
java.net.ConnectException: Connection refused: connect
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(Unknown Source)
at sun.rmi.transport.tcp.TCPChannel.createConnection(Unknown Source)
at sun.rmi.transport.tcp.TCPChannel.newConnection(Unknown Source)
at sun.rmi.server.UnicastRef.invoke(Unknown Source)
at java.rmi.server.RemoteObjectInvocationHandler.invokeRemoteMethod(Unknown Source)
at java.rmi.server.RemoteObjectInvocationHandler.invoke(Unknown Source)
at $Proxy0.getAllSections(Unknown Source)
at ccg.boccrawler.rmi.TestClient.main(TestClient.java:21)
127.0.0.1这个地址让我纳闷了很久,网上找了很多资料,也尝试了不同的获取MBeanServerConnection的方法,还是没能解决,最后发现 原因如下:
这个问题其实是由rmi服务器端程序造成的。 客户端程序向服务端请求一个对象的时候,返回的stub对象里面包含了服务器的hostname,客户端的后续操作根据这个hostname来连接服务器端。要想知道这个hostname具体是什么值可以在服务器端bash中打入指令:hostname -i 如果返回的是127.0.0.1,那么你的客户端肯定会抛如标题的异常了。
解决方法:
1:/etc/hosts里的127.0.0.1修改为实际的IP地址(这种方法可能会导致有些应用不能用,不推荐)
2:先在/etc/hosts里添加一行,然后修改/etc/sysconfig/network文件里面的HOSTNAME
如你的hosts文件原来内容
#Do not remove the following line, or various programs
#that require network functionality will fail.
127.0.0.1 localhost.localdomain localhost
机器的实际IP为10.1.60.121,则可以添加以下内容
10.1.60.14 test localhost
然后修改/etc/sysconfig/network文件的HOSTNAME=test,则可以访问成功。
补充:http://scork520.blog.163.com/blog/static/49099202201081324215183/ 这篇文章中讲到了 hostname的配置以及与hosts文件的作用,大家看下应该很有帮助。