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

最近使用 jmx 遇到一个问题,client/server 同在一台机器上,jmx client能够成功连接 server,如果把 server 移植到另一台机器上192.168.134.128,抛出如下异常:

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) 

原因:这个问题其实是由 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 文件原来内容

[root@test132 /]# vim /etc/hosts

127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

机器的实际 IP 为192.168.134.132,则可以添加以下内容

192.168.134.132 test132 localhost

然后修改 /etc/sysconfig/network 文件的 HOSTNAME=test,则可以访问成功。

[root@test132 /]# vim /etc/sysconfig/network

# Created by anaconda
HOSTNAME=test132

补充:http://scork520.blog.163.com/blog/static/49099202201081324215183/ 这篇文章中讲到了 hostname 的配置以及与 hosts 文件的作用,大家看下应该很有帮助。

posted @ 2019-01-03 16:39  挖坑埋你  阅读(8770)  评论(0编辑  收藏  举报