Rmi连接被localhost拒绝

我使用java rmi时遇到问题:

当我试图运行我的服务器时,我得到一个connectException(见下文)。

执行重新绑定方法时发生exception:

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

当使用rmi:// localhost:2020 / RemoteDataPointHandler时,它也不起作用。 使用默认端口也不起作用。 我也尝试过使用127.0.0.1的ip-address,但效果相同。

我的运行时args:

 -Djava.security.policy=java.security.AllPermission 
线程“main”中的exceptionjava.rmi.ConnectException:Connection拒绝主机:localhost; 嵌套exception是: 
     java.net.ConnectException:连接被拒绝
     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)
    在java.rmi.Naming.rebind(Naming.java:160)
    在be.fortega.knx.server.Main。(Main.java:25)
    在be.fortega.knx.server.Main.main(Main.java:16)
引起:java.net.ConnectException:连接被拒绝
     at java.net.PlainSocketImpl.socketConnect(Native Method)
    在java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
    在java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
    在java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
    在java.net.SocksSocketImpl.connect(SocksSocketImpl.java:433)
    在java.net.Socket.connect(Socket.java:524)
    在java.net.Socket.connect(Socket.java:474)
    在java.net.Socket。(Socket.java:371)
    在java.net.Socket。(Socket.java:184)
     at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:22)
    在sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:128)
     at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:569)
     ......还有7个

有一个连接exception的simliar问题。 当注册表尚未启动时(如在您的情况下)或注册表已经取消导出(如我的情况),它会被抛出。

但对启动注册表的两种方式之间的区别进行简短评论:

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

在新进程中运行javas bin-directory中的rmiregistry.exe并继续与您的java代码并行。

 LocateRegistry.createRegistry(2020); 

rmi方法调用启动注册表,返回对该注册表远程对象的引用,然后继续下一个语句。

在您的情况下,当您尝试绑定对象时,注册表不会及时启动

它似乎在我更换时工作

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

通过

 LocateRegistry.createRegistry(2020); 

有谁知道为什么? 有什么不同?

在尝试连接(注册)RMI服务之前,您需要运行rmiregistry

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; }; 

VM参数

 -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)的样式。