Используется удаленный порт вызова метода - PullRequest
15 голосов
/ 01 декабря 2011

Я создал программу типа Сервер, Клиент с RMI. Но всякий раз, когда я запускаю свой Сервер после запуска rmiregistry из командной строки, выдается ошибка уже используемого порта. Это только я, кто начал rmiregistry. Я проверил это из netstat.

Код сервера:

public class Server implements Runnable, Linker{


private static Server server = null;
    private static Linker l = null;
    private String name = null;
    public Server(){}

    public void setName(String name){
        this.name = name;
    }
    public String getName(){
        return name;               
    }  
    public void run(){
        while(!("Andy").equalsIgnoreCase(name)){

        }
    }
    public static void createStub(){
        try{
            server = new Server();
            l = (Linker) UnicastRemoteObject.exportObject(server, 1099);

            Registry registry = LocateRegistry.getRegistry();
            registry.bind("Link", l);
            System.out.println("Ready");
        }
        catch(Exception e){
            e.printStackTrace();
        }
    }                       
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        createStub();
        Thread t = new Thread(server);

    }
}

Код клиента:

public class Client implements Runnable{


private Scanner sc = new Scanner(System.in);
    private Linker linker = null;

    public void loadStub(){
        try{
            Registry registry = LocateRegistry.getRegistry(1099);
            linker = (Linker) registry.lookup("Link");

        }catch(Exception e){

        }
    }
    public void run(){
        String ip = null;
        while(sc.hasNext()&&!(ip = sc.nextLine()).equalsIgnoreCase(":q")){
            try {
                linker.setName(ip);
            } catch (RemoteException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }


    public static void main(String...args){
        Client client = new Client();
        client.loadStub();
        Thread t = new Thread(client);
        t.start();
    }
}

Исключение:

java.rmi.server.ExportException: Port already in use: 1099; nested exception is: 
java.net.BindException: Address already in use: JVM_Bind

Ответы [ 6 ]

42 голосов
/ 12 марта 2014

Если вы используете macOS, вы можете остановить следующий порт следующим образом:

Прежде всего вам нужно найти PID_number: lsof -i :1099

И затем убить этот порт: kill -9 PID_number

7 голосов
/ 01 декабря 2011

Использовать этот код сервера -

Registry registry = null;
try {
    registry = LocateRegistry.getRegistry(52365);//use any no. less than 55000
    registry.list();
    // This call will throw an exception if the registry does not already exist
}
catch (RemoteException e) { 
    registry = LocateRegistry.createRegistry(52365);
}
7 голосов
/ 01 декабря 2011

rmiregistry использует порт 1099 в своем процессе, поэтому вы не можете использовать его в своем. Или:

  1. Запустите реестр в том же процессе с помощью LocateRegistry.createRegistry() (предпочтительно).
  2. Экспорт вашего объекта на другой порт.
  3. Запустите rmiregistry на другом порту, отличном от 1099.
1 голос
/ 28 декабря 2017

Попробуйте это:

lsof -P | grep ':1099' | awk '{print $2}' | xargs kill -9
1 голос
/ 05 июля 2014

Используйте ps -aef | grep rmiregistry. найдите pid, который использует rmiregistry. Убить пид Ден снова запустить сервер ... !!!!

1 голос
/ 01 декабря 2011

Еще раз проверьте, не используется ли порт 1099 каким-либо другим процессом или пользователем, или запустите rmiregistry на каком-либо другом порту.

...