我正在构建可能每秒可能有大量请求的API,而某些请求可能需要大量计算(复杂报告)。我被要求将一个小型原型放在一起作为概念的证明。我使用带有Jersey的Spring Boot作为我的JAX-RS实现。在过去,我用Spring MVC做过类似的事情。
@RequestMapping(value = "/dashboard", method = RequestMethod.GET)
public DeferredResult<String> showDashboard(Model model) {
DeferredResult<String> result = new DeferredResult<>();
model.addAttribute("testObj", new User());
result.setResult("home/dashboard");
return result;
}
我在泽西岛试过这个并且看起来有效,或者至少它没有抛出错误。
@GET
public DeferredResult<String> getClients() {
DeferredResult<String> deferredResult = new DeferredResult<>();
deferredResult.setResult("Nothing! But I'm Async!");
return deferredResult;
}
然而,我在Jersey中异步处理操作的所有示例都是这样的。
Produces(MediaType.TEXT_PLAIN)
public void get(@Suspended final AsyncResponse response) {
// This call does not block.
client.callExternalService(
// This callback is invoked after the external service responds.
new Callback<string>() {
public void callback(String result) {
response.resume("Result: " + result + ".n");
}
});
}
我的主要问题是幕后这三个代码片段之间的区别是什么,如果有的话。这些都会完成同样的事情吗?
有没有更好的方法来完成异步?我也看过在Java中使用Future,但从未使用它。
更新:
我的Jersey控制器中有以下代码,它们都在工作。
@GET
public String getClients() {
return "Nothing, I'm Sync!";
}
@GET
@Path("/deferred")
public DeferredResult<String> getClientsAsync() {
DeferredResult<String> deferredResult = new DeferredResult<>();
deferredResult.setResult("Nothing! But I'm Async!");
return deferredResult;
}
@GET
@Path("/async")
public void getClientsJAXRSAsync(@Suspended AsyncResponse response) {
new Thread(() -> {
response.resume("I am Async too! But I am using @Suspended");
}).start();
}
这回到我的主要问题,这些有什么区别?我的理解是DeferredResult是一个Spring的东西所以不确定它是否适合与Jersey一起使用,尽管我使用的是Jersey + Spring。
答案 0 :(得分:-3)
你的理解是完全正确的。两个人都在做同样的工作。但是实施是不同的。 DeferredResult是spring的实现。在您的代码库中,大部分内容都是JAX-RS实现。我不确定你是否得到了第一次服务的回复。
但我的观点是,要么使用spring类,要么使用JAX-RS。但不是两者都采用相同的方法。