Rmi连接被localhost拒绝

时间:2009-12-01 00:26:27

标签: java connection localhost rmi

我在使用java rmi时遇到了问题:

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

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

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

5 个答案:

答案 0 :(得分:13)

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

但是对启动注册表的两种方式之间差异的简短评论:

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

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

LocateRegistry.createRegistry(2020);

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

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

答案 1 :(得分:8)

当我更换

时似乎有效
Runtime.getRuntime().exec("rmiregistry 2020");

通过

LocateRegistry.createRegistry(2020);
谁知道为什么?有什么区别?

答案 2 :(得分:6)

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

LocateRegistry.createRegistry(2020)方法调用在指定的端口号上创建并导出注册表。

请参阅LocateRegistry

的文档

答案 3 :(得分:1)

我们在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();
    }
  }
}

答案 4 :(得分:0)

似乎您应该将命令设置为String[],例如:

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

就像main(String[] args)的风格一样。