Java rmi:
サーバーを実行しようとすると、connectExceptionが発生します(以下を参照)。
Rebindメソッドを実行すると例外が発生します。
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を使用してみましたが、同じ効果がありました。
私のランタイム引数:
-Djava.security.policy=Java.security.AllPermission
スレッド「メイン」の例外Java.rmi.ConnectException:ホストへの接続が拒否されました:localhost;ネストされた例外は次のとおりです: Java.net.ConnectException:Sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.Java:574) で接続が拒否されました .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) 原因:Java.net.ConnectException:接続が拒否されました 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) Sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.Java:22) at Sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.Java:128) Sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.Java:569) ... 7つ以上
交換するとうまくいくようです
Runtime.getRuntime().exec("rmiregistry 2020");
沿って
LocateRegistry.createRegistry(2020);
誰もがなぜアイデアを考えていますか?違いは何ですか?
その接続の例外と同様の問題がありました。レジストリがまだ起動されていない場合(あなたの場合など)またはレジストリが既にエクスポートされていない場合(私の場合など)にスローされます。
しかし、レジストリを起動する2つの方法の違いに対する短いコメント:
Runtime.getRuntime().exec("rmiregistry 2020");
新しいプロセスのjavas bin-directoryでrmiregistry.exeを実行し、Javaコードと並行して続行します。
LocateRegistry.createRegistry(2020);
rmiメソッド呼び出しは、レジストリを開始し、そのレジストリリモートオブジェクトへの参照を返し、次のステートメントを続行します。
あなたの場合、オブジェクトをバインドしようとしたときにレジストリが間に合わない
RMIサービスに接続(登録)する前に、rmiregistry
を実行する必要があります。
LocateRegistry.createRegistry(2020)
メソッド呼び出しは、指定されたポート番号でレジストリを作成およびエクスポートします。
LocateRegistry のドキュメントを参照してください
Windowsで確認できる1つの違いは次のとおりです。
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)
のスタイルと同じです。