异步Servlet的理解与实践
AsyncContext理解
Servlet 3.0(JSR315)定义了Servlet/Filter的异步特性规范.
怎么理解"异步Servlet/Filter"及其使用情景?
Servlet3.0以前
流程:
容器初始化ServletRequest与ServletResponse对象.
容器调用Servlet实例的service(ServletRequest, ServletResponse)执行业务逻辑.
容器Commit ServletResponse, 将响应结果写回客户端并关闭连接.
- Servlet接口定义
public interface Servlet {
public void init(ServletConfig config) throws ServletException;
public void service(ServletRequest req, ServletResponse res)
throws ServletException, IOException;
public void destroy(); public ServletConfig getServletConfig();
public String getServletInfo();
}
- Filter接口定义
public interface Filter{
public void init(FilterConfig filterConfig) throws ServletException; }
局限
- 执行完流程(2)后立即Commit ServletResponse, 将响应结果回写给客户端.
- 局限(1)导致请求的所有业务逻辑都必须在service()方法内同步执行.
- 局限(2)导致容器的控制线程耗用严重, 特别是长连接或者阻塞等待(DB,IO,Net)的情景.
看到这里, 是不是有点明白了!
Servlet 3.0前, Service容器调用Servlet.service()方法后就会Commit与销毁ServletResponse, 这导致所有业务逻辑都必须在service()内处理, 不管理是耗时还是不耗时的, 控制线程必须等待处理完成才能"抽身"服务新的请求.
Servlet 3.0 规范提供AsyncContext设施实现ServletResponse的delay commit.
AsyncContext原理
通过ServletRequest.startAsync()通知Servlet容器delay ServletResponse的committal, 并返回AsyncContext对象供其他线程在service()方法结束后使用.
AsyncContext套路
设置asyncSupported=true.
- 在<servlet>或<filter>内使用<async-supported>标签
- 在@WebServlet或@WebFilter内使用asyncSupported属性
调用ServletRequest.startAsyc()通知容器delay ServletResponse的committal, 并返回AsyncContext对象.
调用AsycContext.setTimeout()设置超时; 调用AsyncContext.addListener()添加监听器,设置start/timeout/error/complete的回调方法.
将AsyncContext对象交给工作线程处理.
- 自定义线程池: ThreadPoolExecutor
- 容器线程池: AsyncContext.start()
控制线程继续服务其他请求.
工作线程完成处理, 响应结果回写客户端.
- 正常完成: 手工调用AsyncContext.complete()
- 处理超时或发生错误, 自动调用AsyncContext.complete().
只有AsyncContext.complete(), ServletResponse才会提交, 响应结果才会回写客户端. - 分发其他: 调用dispatch分发其他Servlet处理.
最佳实践: 慎重AsyncContext.setTimeout(0)
AsyncContext相关的API:
ServletRequest:
- ServletRequest.isAsyncSupported()
- ServletRequest.isAsyncStarted()
- ServletRequest.startAsync(...) #多个
- ServletRequest.getAsyncContext()
AsyncContext:
可分成下述几类
- AsyncContext.getRequest()/getResponse()/hasOriginalRequestAndResponse()
- AsyncContext.setTimeout()/getTimeout()
- AsyncContext.addListener(...)/createListener()
- AsyncContext.complete()/dispatch(...)
- AsyncContext.start()
异步Servlet的理解与实践的更多相关文章
- Java网络编程中异步编程的理解
目录 前言 一.异步,同步,阻塞和非阻塞的理解 二.异步编程从用户层面和框架层面不同角度的理解 用户角度的理解 框架角度的理解 三.为什么使用异步 四.理解这些能在实际中的应用 六.困惑 参考文章 前 ...
- Atitit.异步编程技术原理与实践attilax总结
Atitit.异步编程技术原理与实践attilax总结 1. 俩种实现模式 类库方式,以及语言方式,java futuretask ,c# await1 2. 事件(中断)机制1 3. Await 模 ...
- Servlet 3特性:异步Servlet
解异步Servlet之前,让我们试着理解为什么需要它.假设我们有一个Servlet需要很多的时间来处理,类似下面的内容: LongRunningServlet.java package com.jou ...
- 异步servlet的原理探究
异步servlet是servlet3.0开始支持的,对于单次访问来讲,同步的servlet相比异步的servlet在响应时长上并不会带来变化(这也是常见的误区之一),但对于高并发的服务而言异步serv ...
- 使用tomcat7创建异步servlet
该篇文章翻译自:http://developerlife.com/tutorials/?p=1437 一.简介 Servlet API 3.0 之前,需要使用类似Comet的方式来实现创建异步的Ser ...
- tornado异步请求的理解(转)
tornado异步请求的理解 http://www.kankanews.com/ICkengine/archives/88953.shtml 官网第一段话: Tornado is a Python w ...
- Filter 快速开始 异步Servlet 异步请求 AsyncContext 异步线程 异步派发 过滤器拦截
[web.xml] <filter> <filter-name>normalFilter</filter-name> <filter-class>net ...
- 异步Servlet和异步过虑器
异步处理功能可以节约容器线程.此功能的作用是释放正在等待完成的线程,是该线程能够被另一请求所使用. 要编写支持异步处理的 Servlet 或者过虑器,需要设置 asyncSupported 属性为 t ...
- 关于servlet3.0中的异步servlet
刚看了一下维基百科上的介绍,servlet3.0是2009年随着JavaEE6.0发布的: 到现在已经有六七年的时间了,在我第一次接触java的时候(2011年),servlet3.0就已经出现很久了 ...
随机推荐
- 从源码角度实现一个自己的Promise
原文链接:https://geniuspeng.github.io/2017/12/14/my-promise/ 关于Promise的概念以及意义就不在这里介绍了,最近看到了一些实现Promise的核 ...
- 怎样推断DIV中的内容为空
怎样推断DIV中的内容为空 1.问题背景 推断div内部是否为空.假设为空,给出无数据提示:否则显示正常页面 2.设计源代码 <!DOCTYPE html PUBLIC "-//W3C ...
- JMS是一种应用于异步消息传递的标准API
JMS是一种应用于异步消息传递的标准API,作为Java平台的一部分,JMS可以允许不同应用.不同模块之间实现可靠.异步数据通信.一些概念 JMS provider An implementat ...
- 创建、删除swap分区
创建 dd if=/dev/zero of=/data/swap bs=1M count=4000 mkswap /data/swap swapon /data/swap chmod 060 ...
- Android 截取手机屏幕两种实现方案解析
近期在开发的过程中,遇到了一个须要截取屏幕保存为图片的需求,详细为截取webview的视图保存图片. 方法1:首先想到的思路是利用SDK提供的View.getDrawingCache()方法: pub ...
- Matlab矩阵基础
一.创建矩阵 1.通过直接赋值创建矩阵 将矩阵元素置于[]中.同行元素之间用空格或"."分开.行与行之间用":"隔开. >> a=[1,2,3;4, ...
- 【hdu 2486】A simple stone game
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...
- tomcat 去除端口和项目名/使用域名访问/修改超链接为IP地址
1.打开tomcat/conf/server.xml 在host标签中加入 <Context docBase="项目名" path="" reloada ...
- NSUserDefaults:通常用来保存一些小巧的数据,如用户的用户名密码,或者是用户的使用习惯,如是否自动打开背景音乐等。
1,NSUserDefaults通常用来保存一些小巧的数据,如用户的用户名密码,或者是用户的使用习惯,如是否自动打开背景音乐等. 2,使用它的原因就是:代码简短,使用方便 3,使用方法如下: -(vo ...
- js声明json数据,打印json数据,遍历json数据,转换json数据为数组
1.js声明json数据: 2.打印json数据: 3.遍历json数据: 4.转换json数据为数组; //声明JSON var json = {}; json.a = 1; //第一种赋值方式(仿 ...