Java RMI超时

时间:2016-02-15 21:38:49

标签: java server timeout client rmi

我使用Java RMI编写了一个客户端/服务器应用程序。当我在本地运行此应用程序(客户端和服务器中的IP-String设置为本地IP)时,脚本运行正常。

客户代码:

public class ClientMain {
public static void main(String[] args) {


    String ip = "123.123.123.123"; // (my server's IP)


    IUserHandler userHandler;
    try {
        userHandler = (IUserHandler) Naming.lookup("//"+ip+"/Server");
        System.out.println(userHandler.attachUser(new User("John")));
    } catch (Exception e) {
        e.printStackTrace();
    }
  }
}

服务器代码:

public class MainServer {
public static void main(String[] args) {

    String ip = "123.123.123.123"; // (my server's IP)

    System.out.println("Start Server at " + ip);
    try {
        System.setProperty("java.rmi.server.hostname",ip);
        LocateRegistry.createRegistry(Registry.REGISTRY_PORT);
        Naming.rebind("Server",new UserHandler());

        System.out.println("Server is running");
    } catch (Exception ex) {
        System.out.println(ex.getMessage());
    }   
}
}

现在将User和UserHandler的接口和类传输到服务器:

界面IUser:

public interface IUser extends Remote {
   public String getUserName() throws RemoteException;
   public void setUserName(String name) throws RemoteException;
}

接口IUserHandler:

public interface IUserHandler extends Remote {
   public int attachUser(IUser user) throws RemoteException;
   public int detachUser(String name) throws RemoteException;
}

Class UserHandler:

public class UserHandler extends UnicastRemoteObject implements IUserHandler {  
public UserHandler() throws RemoteException {}

@Override
public int attachUser(IUser user) throws RemoteException {
    System.out.println(user.getUserName() + " logged in");  
    return 1;
}

@Override
public int detachUser(String name) throws RemoteException{
    return 1;
}
}

班级用户:

public class User extends UnicastRemoteObject implements IUser {
private String name;

public User(String name) throws RemoteException {
    super();
    this.name = name;
}

@Override
public String getUserName() {
    return name;
}

@Override
public void setUserName(String name) {
    this.name = name;
}

}

服务器应用程序应该在Windows Server 2012计算机上运行。当我在服务器上运行生成的jar时,它启动正常。

因此,在类UserHandler中有以下行:

System.out.println(user.getUserName() + " logged in");  

当只打印没有任何用户对象的String时,在客户端执行该方法后,打印的行会出现提示 当只打印带有用户的println(但没有方法调用getUserNAme())时,打印需要10-15秒。 使用上面的语句,没有任何反应,我得到超时异常。

在测试环境中,我打开TCP的所有端口以确保消息到达。

有人可以帮帮我吗?谢谢!

1 个答案:

答案 0 :(得分:1)

您正在使用回调,这意味着您正在打开与客户端的连接,这意味着客户端的防火墙必须处于打开状态。

我强烈建议你摆脱回调并使User成为Serializable对象。