java.rmi.ConnectIOException

时间:2012-10-14 00:43:50

标签: java rmi

我目前正在阅读Head First Java书籍并阅读了RMI章节。我完全按照书中的方式复制了所有内容,但我仍然遇到这个RMI问题。

这是错误的堆栈跟踪。

java.rmi.ConnectIOException: Exception creating connection to: 192.168.0.110; nested exception is: 
    java.net.NoRouteToHostException: No route to host
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:632)
    at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:216)
    at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202)
    at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:340)
    at sun.rmi.registry.RegistryImpl_Stub.rebind(Unknown Source)
    at java.rmi.Naming.rebind(Naming.java:177)
    at MyRemoteImpl.main(MyRemoteImpl.java:15)
Caused by: java.net.NoRouteToHostException: No route to host
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339)
    at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
    at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:391)
    at java.net.Socket.connect(Socket.java:579)
    at java.net.Socket.connect(Socket.java:528)
    at java.net.Socket.<init>(Socket.java:425)
    at java.net.Socket.<init>(Socket.java:208)
    at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40)
    at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:146)
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613)
    ... 6 more

我真的不知道这意味着什么,所以就是这样。

如果您还需要其他任何内容,请提出并回答。

由于

2 个答案:

答案 0 :(得分:2)

这不是RMI问题。它表示尝试将套接字连接到远程地址和端口时发生错误。通常,由于中间防火墙或中间路由器关闭,无法访问远程主机。

请参阅javadocs here

之所以发生这种情况,是因为您逐字复制了示例。您必须将192.168.0.110替换为真实的,有效的主机地址。

跟踪中的这一行:

at java.rmi.Naming.rebind(Naming.java:177)

显示Naming.rebind()方法无法使用该IP地址。请检查服务器代码并在其中输入正确的IP地址。如果它不在代码本身中,请在配置文件中查找。

答案 1 :(得分:0)

大部分时间都是防火墙的原因,您可以尝试关闭防火墙以确认原因

service iptables stop