我创建了一个简单的Jersey客户端,它能够成功地执行带有效负载的POST请求。但是现在它等待来自http端点的响应:
public void callEndpoint(String endpoint, String payload) {
try {
ClientConfig config = new DefaultClientConfig();
Client client = Client.create(config);
WebResource webResource = client.resource(getBaseURI(endpoint));
log.debug("Sending payload [" + payload + "] to URL - [" + getBaseURI(endpoint) + "]");
// POST method - Is this blocking?
// Is it possible to not wait for response here
ClientResponse response = webResource.accept("application/json")
.type("application/json")
.post(ClientResponse.class, payload);
if (response.getStatus() != 200) {
log.error("The endpoint [" + getBaseURI(endpoint) + "] returned a non 200 status code [" + response.getStatus() + "] ");
}
} catch (Exception e) {
log.error("The endpoint for " + endpoint + " - " + getBaseURI(endpoint) + " is not reachable. This is the exception - " + e);
}
}
private URI getBaseURI(String endpoint) {
// Get this URI from config
String URL = "http://www.somewhere.com/v2/" + endpoint;
return UriBuilder.fromUri(URL).build();
}
问题:代码是否有可能不等待响应。
我试图阅读Jersey client docs以查找我的代码是否可能不等待响应?我看到我们只能在读取响应后关闭连接,但在我的情况下它没用。我希望在将有效负载发布到端点后立即关闭连接。
我只需要触发并忘记POST请求,因为我不关心响应。这是因为处理在该端点上花费了大量时间,我不希望线程等待处理。
是否可以等待某些请求的响应,但不是全部?我可以在客户端设置一个参数,使其等待/不等待吗?我仍然在阅读java文档,所以这可能是一个非常简单的设置,但我到目前为止无法找到所以在这里询问。谢谢!
[更新]
我使用以下代码,但是当我运行我的java示例代码时,它会打印 start&立即完成,但程序会继续运行一段时间然后退出。我猜它在等待Future的响应,所以我可以让我的脚本不等待它吗?代码是:
public static void callEndpoint(String endpoint, String payload) {
try {
ClientConfig config = new DefaultClientConfig();
Client client = Client.create(config);
AsyncWebResource webResource = client.asyncResource(getBaseURI(endpoint));
// POST method
System.out.println("start");
Future<ClientResponse> resp = webResource.accept("application/json")
.type("application/json")
.post(ClientResponse.class, payload);
// This line makes the code wait for output
//System.out.println(resp.get());
} catch (Exception e) {
System.out.println ("The endpoint for " + endpoint + " - " + getBaseURI(endpoint) + " is not reachable. This is the exception - " + e);
}
System.out.println("done");
}
答案 0 :(得分:1)
我使用TypeListener使它真正异步。收到响应后,将调用onComplete方法。
webResource.post(new TypeListener<ClientResponse>(ClientResponse.class) {
@Override
public void onComplete(Future<ClientResponse> f) throws InterruptedException {
try {
ClientResponse response = f.get();
if (response == null || response.getClientResponseStatus() != Status.OK) {
System.err.println(" Async " + response.getClientResponseStatus()+" "+response.getStatus());
} else{
System.out.println(" Async " + response.getClientResponseStatus()+" "+response.getStatus()+" "+response.getEntity(String.class));
}
} catch (ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
答案 1 :(得分:0)
我的回复有点晚,但是我似乎可以解决您的两个问题。希望它将来能对某人有所帮助。
我会简短介绍一下该平台上已经问过的问题
对于第一个问题,您不想在这里等待。您可以在其客户端对象中使用jersey提供的超时属性。以下是解决此问题的链接。 How to set the connection and read timeout with Jersey 2.x?
对于第二个问题,您可以看到它仅在运行一段时间后才停止,这是因为客户端线程一直运行直到超时。请在下面找到具有更好描述的链接 JerseyClient async calls seems to leave hanging threads