【问题标题】:java.rmi.ConnectException: Connection refused to host: 192.168.1.8; nested exception is:java.rmi.ConnectException:连接拒绝主机:192.168.1.8;嵌套异常是:
【发布时间】:2015-04-27 10:57:08
【问题描述】:

我正在尝试创建一个基于 java RMI 的文件共享应用程序。它会抛出一个ConnectException 虽然我能够分别从对方ping 客户端和服务器的IP 地址

使用本地主机时,整个代码运行良好,但失败了 在由 2 个系统和一个 路由器。

FileClientInitialise(Server) 的来源:-

import java.rmi.Remote;
import java.rmi.RemoteException;

public interface FileClientInitialise extends Remote{
    public boolean sendData(String fileName, byte[] data, int len) throws RemoteException;
    public String getName() throws RemoteException;
}

FileServerInitialise(Server) 的来源:-

import java.rmi.Remote;
import java.rmi.RemoteException;

public interface FileServerInitialise extends Remote{
    public boolean login(FileClientInitialise fci) throws RemoteException;
}

文件服务器(服务器)的来源:-

import java.io.File;
import java.io.FileInputStream;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

public class FileServer extends UnicastRemoteObject implements FileServerInitialise{

    private String file="";
    protected FileServer() throws RemoteException{
        super();
    }

    public void setFile(String f){
        file=f;
    }

    @Override
    public boolean login(FileClientInitialise fci) throws RemoteException {
        try{
           File f1 = new File(file);
            FileInputStream fis = new FileInputStream(f1);
            byte[] myData = new byte[4096];
            int dataLen = fis.read(myData);
            while(dataLen>0){
                fci.sendData(f1.getName(),myData,dataLen);
                dataLen = fis.read(myData);
            }
        }
        catch(Exception e){
            e.printStackTrace();
        }
        return true;
    }

}

StartFileServer(Server) 的来源:-

    import java.net.InetAddress;
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

public class StartFileServer {
public static void main(String[] args) {
// TODO Auto-generated method stub
try{
    System.setProperty("java.rmi.server.hostname","192.168.1.8");
Registry registry=LocateRegistry.createRegistry(1099);
System.out.println("Server Started--- GO,GO,GO--- "+"\nThis Server's IP --- "+InetAddress.getByName("SERVER-1")+"\n");
FileServer fs=new FileServer();
fs.setFile("/root/Downloads/XSS.mp4");  
registry.rebind("asad",fs);
System.out.println("File Server is Ready");
String sa[]=Naming.list("Uploaded");
for(String s: sa){
    System.out.println("Value of s=" + s);
}
}
catch(Exception e){
e.printStackTrace();
}
}   
}

FileClientInitialise.java 的客户端代码和 文件服务器初始化.java。其余的客户端代码是:-

FileClient.java(Client) 的来源:-

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;
import java.util.*;

public class FileClient extends UnicastRemoteObject implements FileClientInitialise {
/**
*
*/
private static final long serialVersionUID = 1L;
public String name;
public FileClient (String n) throws RemoteException {
super();
name=n;
}

@Override
public String getName() throws RemoteException{
return name;
}
@Override
public boolean sendData(String filename, byte[] data, int len) throws RemoteException{
try{
File f=new File(filename);
f.createNewFile();
FileOutputStream out=new FileOutputStream(f,true);
out.write(data,0,len);
out.flush();
out.close();
System.out.println("Done writing data...");
}catch(Exception e){
e.printStackTrace();
}
return true;
}
}

StartFileClient.java(Client) 的源代码:-

import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.util.Scanner;


public class StartFileClient {

public static void main(String[] args) {
try{
Registry registry=LocateRegistry.getRegistry(1099);
FileClient c=new FileClient("imed");
FileServerInitialise server=(FileServerInitialise)registry.lookup("asad");   
//exception being thrown here in above line ---> registry.lookup("asad") method...
server.login(c) ;
System.out.println("Listening.....");   
Scanner s=new Scanner(System.in);   
/*while(true){
String line=s.nextLine();
}*/
}
catch(Exception e){
e.printStackTrace();
}
}   

}

在客户端抛出的异常的堆栈跟踪是:-

java.rmi.ConnectException: Connection refused to host: 192.168.1.8;
nested exception is:    java.net.ConnectException: Connection refused
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:619)
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:342)   at
sun.rmi.registry.RegistryImpl_Stub.lookup(Unknown Source)   at
StartFileClient.main(StartFileClient.java:23)
Caused by: java.net.ConnectException: Connection refused    at     java.net.PlainSocketImpl.socketConnect(Native Method)    at
java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:345)
at
java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
at
java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)   at
java.net.Socket.connect(Socket.java:589)    at
java.net.Socket.connect(Socket.java:538)    at
java.net.Socket.<init>(Socket.java:434)     at
java.net.Socket.<init>(Socket.java:211)     at
sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40)
at
sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:148)
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613)
... 5 more

【问题讨论】:

  • @Kayaman-这里没有 servlet,您需要检查问题。这些要么是简单的类,要么是简单的接口!
  • 呃,我指的是服务器,不是 servlet。
  • 嗯,端口在服务器上成功运行,我已经检查过了。 @Kayaman
  • 端口不运行,所以我想知道您检查了什么。可以telnet或者netcat连接到端口吗?
  • 嗯,例外很明显“连接被拒绝”。最好仔细检查所有内容。

标签: java network-programming rmi


【解决方案1】:

您需要在服务器中将Registry 引用变量设为静态。否则它可能会被垃圾回收,最终会导致一切退出。

【讨论】:

  • 抱歉,我无法理解您的说法,PARDON。您能否通过一些代码或链接提出建议?
  • 将服务器中的Registry registry变量设为静态。
  • @EJP-对不起,先生,但这不能满足目的!请提出任何其他可行的选择。此外,我在此回复中发布了一个新问题,因为我在执行一些更改后遇到了一个新错误。
猜你喜欢
  • 1970-01-01
  • 2013-07-06
  • 2017-05-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-02-10
  • 2021-12-15
相关资源
最近更新 更多