我正在浏览sun网站上的教程,尝试使用RMI。
但是当我尝试启动服务器时,我收到了这个错误:
ComputeEngine exception:
java.security.AccessControlException: access denied ("java.net.SocketPermission" "127.0.0.1:1099" "connect,resolve")
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:372)
at java.security.AccessController.checkPermission(AccessController.java:559)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
at java.lang.SecurityManager.checkConnect(SecurityManager.java:1051)
at java.net.Socket.connect(Socket.java:574)
at java.net.Socket.connect(Socket.java:528)
at java.net.Socket.<init>(Socket.java:425)
at java.net.Socket.<init>(Socket.java:208)
at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40)
at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:146)
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613)
at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:216)
at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202)
at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:340)
at sun.rmi.registry.RegistryImpl_Stub.rebind(Unknown Source)
at engine.ComputeEngine.main(ComputeEngine.java:31)
有人可以就如何解决这个问题提出建议吗?我如何摆脱这个异常,我该如何解决?
这是我得到异常的地方(我画了右边的箭头):
package engine;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.UnicastRemoteObject;
import compute.Compute;
import compute.Task;
public class ComputeEngine implements Compute {
public ComputeEngine() {
super();
}
public <T> T executeTask(Task<T> t) {
return t.execute();
}
public static void main(String[] args) {
if (System.getSecurityManager() == null) {
System.setSecurityManager(new SecurityManager());
}
try {
String name = "Compute";
Compute engine = new ComputeEngine();
Compute stub =
(Compute) UnicastRemoteObject.exportObject(engine, 0);
Registry registry = LocateRegistry.getRegistry();
registry.rebind(name, stub); <<<<<------
System.out.println("ComputeEngine bound");
} catch (Exception e) {
System.err.println("ComputeEngine exception:");
e.printStackTrace();
}
}
}
最后这就是我启动程序的方式:
我将在下面留下可能有用的更多相关信息:
这是文件〜/ .server_policy:
grant codeBase "file:/home/jenia/Documents/eclipse/workspace/asti01/bin" {
permission java.security.AllPermission;
};
这是项目目录的树:
/home/jenia/Documents/eclipse/workspace/asti01$ tree
.
├── bin
│ ├── client
│ │ ├── ComputePi.class
│ │ └── Pi.class
│ ├── compute
│ │ ├── Compute.class
│ │ └── Task.class
│ └── engine
│ └── ComputeEngine.class
└── src
├── client
│ ├── ComputePi.java
│ └── Pi.java
├── compute
│ ├── Compute.java
│ └── Task.java
├── compute.jar
└── engine
└── ComputeEngine.java
这是〜/ public_html
文件夹的树/home/jenia/public_html/
└── classes
├── client
│ └── Pi.class
└── compute.jar
答案 0 :(得分:1)
原始问题的答案是RMI中的EOFException通常是由另一端的SecurityManager问题引起的。在没有代码库和安全管理器的情况下试一试。
您问题的第二个版本的答案是注册表未运行,并且getRegistry()无法启动它。 createRegistry()确实。
您问题的第三个版本的答案与第一个版本的答案相同。
如果您将所有这些错误转移到下一个错误(绑定时无疑是ClassNotFoundException
,则解决方案是使用正确的类路径运行注册表。
当您通过 到达下一个错误时,查找时无疑是ClassNotFoundException
,解决方案是运行客户端使用正确的类路径。
答案 1 :(得分:1)
重申@ EJP的原始评论:
忽略教程中与配置/使用SecurityManager相关的所有内容。不要尝试使用远程代码加载。这些&#34;功能&#34;大大增加了使用rmi的复杂性,99%的用户实际上并不需要它们。
答案 2 :(得分:0)
如果您的RMI Registry Server在Localhost中运行,那么您应该使用127.0.0.1
而不是127.0.1.1
启动127.0.0.1
时传递ComputePi