IT运维笔记


调用远程主机上的RMI服务时抛出java.rmi.ConnectException: Connection refused to host: 127.0.0.1异常原因及解决方案

最近使用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文件的作用,大家看下应该很有帮助。