Spring中注解方式的异步请求
短信预约 -IT技能 免费直播动态提醒
一、Servlet3.0异步请求
@WebServlet(value = "/async", asyncSupported = true)
public class HelloAsyncServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//1、设置支持异步处理asyncSupported = true
//2、开启异步模式
System.out.println("主线程开始:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
AsyncContext startAsync = req.startAsync();
//3、业务逻辑进行异步处理,开始异步处理
startAsync.start(new Runnable() {
@Override
public void run() {
try {
System.out.println("副线程开始:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
sayHello();
//获取到异步的上下文
AsyncContext asyncContext = req.getAsyncContext();
startAsync.complete();
ServletResponse response = asyncContext.getResponse();
response.getWriter().write("hello async!");
System.out.println("副线程结束:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
} catch (Exception e) {
e.printStackTrace();
}
}
});
System.out.println("主线程结束:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
}
public void sayHello() throws Exception {
System.out.println(Thread.currentThread() + "processing...");
Thread.sleep(3000);
}
}
打印结果:
二、SpringMVC的异步请求
返回Callable
@Controller
public class AsyncController {
@ResponseBody
@RequestMapping("/async01")
public Callable<String> async01(){
System.out.println("主线程开始:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
Callable<String> callable = new Callable<String>() {
public String call() throws Exception {
System.out.println("副线程开始:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
Thread.sleep(2000);
System.out.println("副线程开始:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
return "async01";
}
};
System.out.println("主线程结束:" + Thread.currentThread() + "==>" + System.currentTimeMillis());
return callable;
}
}
- 控制器返回
Callable
- Spring进行异步处理,将
Callable
提交给TaskExecutor
,使用一个隔离的线程进行执行 DispatcherServlet
和所有的Filter
退出Web容器的线程,但是response
保持打开状态Callable
返回结果,SpreingMVC将请求重新派发给容器,恢复之前的处理,Callable
返回值就是目标方法的返回值- 根据
Callable
返回的结果,SpringMVC继续进行视图渲染流程等(从收到请求到视图渲染)
输出结果:
返回DeferredResult
模拟一个消息中间件
public class DeferredResultQueue {
private static Queue<DeferredResult<Object>> queue = new ConcurrentLinkedDeque<DeferredResult<Object>>();
public static void save(DeferredResult<Object> deferredResult){
queue.add(deferredResult);
}
public static DeferredResult<Object> get(){
return queue.poll();
}
}
/createOrder
请求会暂时保存DeferredResultQueue
中,/create
请求会获取DeferredResultQueue
中的请求,进行业务逻辑的处理并返回结果
@Controller
public class AsyncController {
@ResponseBody
@RequestMapping("/createOrder")
public DeferredResult<Object> createOrder(){
DeferredResult<Object> deferredResult = new DeferredResult<Object>((long)3000,"create fail");
DeferredResultQueue.save(deferredResult);
return deferredResult;
}
@ResponseBody
@RequestMapping("/create")
public String create(){
String order = UUID.randomUUID().toString();
DeferredResult<Object> deferredResult = DeferredResultQueue.get();
deferredResult.setResult(order);
return "success:" + order;
}
}
到此这篇关于Spring中注解方式的异步请求的文章就介绍到这了,更多相关注解方式的异步请求内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341