Вопрос

У меня проблема с использованием Java RMI:

Когда я пытаюсь запустить свой сервер, я получаю исключение ConnectException (см. ниже).

Исключение возникает при выполнении метода перепривязки:

Runtime.getRuntime().exec("rmiregistry 2020");
MyServer server = new MyServer();
Naming.rebind("//localhost:2020/RemoteDataPointHandler", server);

при использовании вместо этого rmi://localhost:2020/RemoteDataPointHandler это тоже не работает.Также использование порта по умолчанию не работает.Я также пробовал использовать ip-адрес 127.0.0.1, но с тем же эффектом.

мои аргументы времени выполнения:

-Djava.security.policy=java.security.AllPermission
Exception in thread "main" java.rmi.ConnectException: Connection refused to host: localhost; nested exception is: 
    java.net.ConnectException: Connection refused
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:574)
    at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:185)
    at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:171)
    at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:306)
    at sun.rmi.registry.RegistryImpl_Stub.rebind(Unknown Source)
    at java.rmi.Naming.rebind(Naming.java:160)
    at be.fortega.knx.server.Main.(Main.java:25)
    at be.fortega.knx.server.Main.main(Main.java:16)
Caused by: java.net.ConnectException: Connection refused
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
    at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:433)
    at java.net.Socket.connect(Socket.java:524)
    at java.net.Socket.connect(Socket.java:474)
    at java.net.Socket.(Socket.java:371)
    at java.net.Socket.(Socket.java:184)
    at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:22)
    at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:128)
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:569)
    ... 7 more

Это было полезно?

Решение 2

Кажется, это работает, когда я заменяю

Runtime.getRuntime().exec("rmiregistry 2020");

к

LocateRegistry.createRegistry(2020);

у кого-нибудь есть идеи, почему?Какая разница?

Другие советы

была похожая проблема с этим исключением соединения. он генерируется либо когда реестр еще не запущен (как в вашем случае), либо когда реестр уже не экспортирован (как в моем случае).

но краткий комментарий к разнице между двумя способами запуска реестра:

Runtime.getRuntime().exec("rmiregistry 2020");

запускает rmiregistry.exe в bin-каталоге javas в новом процессе и продолжает параллельно с вашим кодом java.

LocateRegistry.createRegistry(2020);

вызов метода rmi запускает реестр, возвращает ссылку на этот удаленный объект реестра, а затем продолжает выполнение следующего оператора.

в вашем случае реестр не запускается вовремя, когда вы пытаетесь связать свой объект

Вам необходимо запустить rmiregistry , прежде чем пытаться подключить (зарегистрировать) службу RMI к нему.

Вызов метода LocateRegistry.createRegistry (2020) создает и экспортирует реестр по указанному номеру порта.

См. документацию по LocateRegistry

Единственное отличие, которое мы можем отметить в Windows, заключается в следующем:

Если вы используете Runtime.getRuntime().exec("rmiregistry 1024");

вы можете увидеть, что процесс rmiregistry.exe запустится в вашем диспетчере задач.

тогда как если вы используете Registry registry = LocateRegistry.createRegistry(1024);

вы не можете видеть запущенный процесс в диспетчере задач,

Я думаю, что Java справляется с этим по-другому.

и это мой файл server.policy

Прежде чем запустить приложение, убедитесь, что вы убили все свои существующие Javaw.exe и rmiregistry.exe соответствует вашим программам RMI, которые уже работают.

Следующий код работает для меня, используя Registry.LocateRegistry() или

Runtime.getRuntime.exec("");


// Standard extensions get all permissions by default

grant {
    permission java.security.AllPermission;
};

Аргумент виртуальной машины

-Djava.rmi.server.codebase=file:\C:\Users\Durai\workspace\RMI2\src\

Код:

package server;    

import java.rmi.Naming;
import java.rmi.RMISecurityManager;
import java.rmi.Remote;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

public class HelloServer 
{
  public static void main (String[] argv) 
  {
    try {

        if(System.getSecurityManager()==null){
            System.setProperty("java.security.policy","C:\\Users\\Durai\\workspace\\RMI\\src\\server\\server.policy");
            System.setSecurityManager(new RMISecurityManager());
        }

 Runtime.getRuntime().exec("rmiregistry 1024");

 //     Registry registry = LocateRegistry.createRegistry(1024);
   //   registry.rebind ("Hello", new Hello ("Hello,From Roseindia.net pvt ltd!"));
   //Process process = Runtime.getRuntime().exec("C:\\Users\\Durai\\workspace\\RMI\\src\\server\\rmi_registry_start.bat");

        Naming.rebind ("//localhost:1024/Hello",new Hello ("Hello,From Roseindia.net pvt ltd!")); 
      System.out.println ("Server is connected and ready for operation.");
    } 
    catch (Exception e) {
      System.out.println ("Server not connected: " + e);
      e.printStackTrace();
    }
  }
}

кажется, что вы должны установить свою команду как String [] , например:

String[] command = new String[]{"rmiregistry","2020"};
Runtime.getRuntime().exec(command);

это так же, как стиль main (String [] args) .

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top