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

グラフとか描いていたと思ったら、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時間。