hanatoyume.net   ~「花とゆめ」ファンサイト風テクノロジと自然の調和と探求~ twitterやめました・・・
ホーム  :  新着記事  :  記事一覧  :  Wiki  :  リンク  :  白泉社 花とゆめ  : 

   

【スタブ】JDK1.6でRMI【不要】

IT・インターネット

グラフとか描いていたと思ったら、RMIのコードを書いている連休前。
JDK1.5以降だとRMIも多少、手間が少なくなって利用できるようです。

スタブ不要なRMI
http://www.02.246.ne.jp/~torutk/javahow2/rmi_nostub.html


Java RMI 実験場
http://www.ki.rim.or.jp/~kuro/Java/RMI/


とりあえず、サンプルコードをまず作ってみるのが一番だと思います。
呼び出し側(クライアント)が受け取るのは、実体じゃなくてインタフェースの方だったり、
レジストリ、サーバ、クライアントそれぞれが共通でクラスを必要としたりするので、
コード設計とかもある程度、RMIに慣れてからでないと、うまくできないかと思います。


素直な人はそんなにてこずるようなアレでもないと思いますが、
私みたいなあわてんぼうががいないとも限らないので、

今日の3時間のハマリ技を披露しておきます。


クライアントを実行するとこういうエラーになります。
(192.168.1.65は実行したPCのアドレス)

java.rmi.ConnectException: Connection refused to host: 192.168.1.65; nested exception is:
java.net.ConnectException: Connection refused: connect
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(Unknown Source)
at sun.rmi.transport.tcp.TCPChannel.createConnection(Unknown Source)
at sun.rmi.transport.tcp.TCPChannel.newConnection(Unknown Source)
at sun.rmi.server.UnicastRef.invoke(Unknown Source)
at java.rmi.server.RemoteObjectInvocationHandler.invokeRemoteMethod(Unknown Source)
at java.rmi.server.RemoteObjectInvocationHandler.invoke(Unknown Source)
at $Proxy0.hello(Unknown Source)
at TestCaller.main(TestCaller.java:14)
Caused by: java.net.ConnectException: Connection refused: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(Unknown Source)
at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
at java.net.PlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(Unknown Source)
at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(Unknown Source)
... 8 more

なんか拒否(Connection refused)されているだけっぽいようなトレースなんで、
ネットワークとか、ホスト名解決とか、そういうところが原因じゃないかと、
思ってしまうわけです。わけなんですが。


サーバー側のコードはこうでした。

public static void main(String[] args) {

  if (System.getSecurityManager() == null) {
    System.setSecurityManager(new RMISecurityManager());
  }

  try {
   MailReceiver hello = new MailReceiver();
   Registry registry = LocateRegistry.getRegistry();
   Naming.rebind("//localhost/HelloObject", hello);
  } catch (Exception e) {
   e.printStackTrace();
  }
 System.exit(0);
}


・・・原因は、System.exit(0);
通常、レジストリも、サーバーも、実行すると、実行しっぱなしになるのですが、
System.exit(0);があると、速攻終わっちゃうようです。
(mainだから何もしなくてもすぐ終わっちゃってるんじゃないかと思うのは早とちり)

・・・というか、こういうのは仕組みがわかんないとハマリやすいよなー


チュートリアルやサンプルは、下手に手を入れちゃいけないよ、ということで。3時間。
 

【スタブ】JDK1.6でRMI【不要】 | 0 件のコメント |
コメントは投稿者の責任においてなされるものであり,サイト管理者は責任を負いません。


トラックバック

このエントリのトラックバックURL: http://www.hanatoyume.net/trackback.php/20090430190202197

この記事にはトラックバック・コメントがありません。