非常に単純なRestletクライアントでテストしている非常に単純なRestletサーバーがあり、すべてRestlet-2.1.0と次の拡張機能を使用しています:xstream-1.4、jettison-1.3。
私の Mac ではすべて問題なく動作しますが、これを SunOS 5.10 で実行しようとすると、サーバーに接続するときにクライアントがハングします。ブラウザまたは telnet からサーバーにアクセスすると応答を取得できます。また、Restlet サーバー以外の他のリソースに接続すると、この同じクライアントが正常に動作します。
スレッド ダンプを見ると、次のように表示されます。
"main" prio=3 tid=0x08070800 nid=0x2 waiting on condition [0xfe0eb000]
java.lang.Thread.State: WAITING (parking)
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <0xbbe827e8> (a java.util.concurrent.CountDownLatch$Sync)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:156)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.parkAndCheckInterrupt(AbstractQueuedSynchronizer.java:811)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.doAcquireSharedInterruptibly(AbstractQueuedSynchronizer.java:969)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireSharedInterruptibly(AbstractQueuedSynchronizer.java:1281)
at java.util.concurrent.CountDownLatch.await(CountDownLatch.java:207)
at org.restlet.engine.connector.ClientConnectionHelper.handle(ClientConnectionHelper.java:517)
at org.restlet.Client.handle(Client.java:180)
at org.restlet.Restlet.handle(Restlet.java:284)
at com.redprairie.task.common.TempClient.main(TempClient.java:17)
ClientResource.get() と Client.handle(Request) の両方を使用してみましたが、両方ともハングしました。
サーバーコード:
server = new Server(Protocol.HTTP, SERVER_PORT, TestServerResource.class);
Context ctx = new Context();
server.setContext(ctx);
server.start();
クライアントコード:
Request request = new Request(Method.GET, "http://localhost:8188/retrieve");
Client client = new Client(Protocol.HTTP);
Response response = client.handle(request);
response.getEntity().write(System.out);
リソース:
public class TestServerResource extends ServerResource {
private static volatile Customer bernard = Customer.createSample();
@Get("json")
public Customer retrieve() {
System.out.println("GET request received");
return bernard;
}
}
xstream および jettison 拡張機能は、Java オブジェクトを JSON に、またはその逆に完全に変換します。また、これは私の Mac OS X では問題なく動作しますが、Sun ではハングします...
私は Restlet を初めて使用するので、何か間違っている可能性がありますが、これらは利用可能なドキュメントから抜粋した簡単な例です。