调用远程主机上的 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 文件的作用,大家看下应该很有帮助。