博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Servlet 3中的异步处理
阅读量:6787 次
发布时间:2019-06-26

本文共 1127 字,大约阅读时间需要 3 分钟。

有人可能会质疑,既然都有多线程了,还需要异步处理请求吗?答案是肯定的,因为如果一个任务处理时间相当长,那么Servlet或Filter会一直占用着请求处理线程直到任务结束,随着并发用户的增加,容器将会遭遇线程超出的风险,这这种情况下很多的请求将会被堆积起来而后续的请求可能会遭遇拒绝服务,直到有资源可以处理请求为止。异步特性可以帮助应用节省容器中的线程,特别适合执行时间长而且用户需要得到结果的任务,如果用户不需要得到结果则直接将一个Runnable对象交给Executor并立即返回即可

 

import
java.io.IOException;
 
import
javax.servlet.AsyncContext;
 
import
javax.servlet.ServletException;
 
import
javax.servlet.annotation.WebServlet;
 
import
javax.servlet.http.HttpServlet;
 
import
javax.servlet.http.HttpServletRequest;
 
import
javax.servlet.http.HttpServletResponse;
 
@WebServlet
(urlPatterns = {
"/async"
}, asyncSupported = 
true
)
 
public
class
AsyncServlet 
extends
HttpServlet {
     
private
static
final
long
serialVersionUID = 1L;
     
@Override
     
public
void
doGet(HttpServletRequest req,
HttpServletResponse resp)
             
throws
ServletException, IOException {
         
// 开启Tomcat异步Servlet支持
         
req.setAttribute(
"org.apache.catalina.ASYNC_SUPPORTED"
true
);
         
final
AsyncContext ctx =
req.startAsync();  
// 启动异步处理的上下文
         
// ctx.setTimeout(30000);
         
ctx.start(
new
Runnable() {
             
@Override
             
public
void
run() {
                 
// 在此处添加异步处理的代码
                 
ctx.complete();
             
}
         
});
     
}
 
}
 
转自   

转载于:https://www.cnblogs.com/xp0813/p/11032852.html

你可能感兴趣的文章
Apache web目录修改
查看>>
Android存储子系统
查看>>
kafka学习笔记五
查看>>
CentOS 6 VNC详细配置
查看>>
html返回json响应键盘?
查看>>
Ubuntu SSH Algorithm negotiation failed
查看>>
使用Custom.pll修改标准Form的LOV
查看>>
Redis 主从复制
查看>>
lucene的使用详解
查看>>
java每日小算法(14)
查看>>
Docker 命令行和后台参数
查看>>
英雄王座的数据库表格部分成功转换
查看>>
AbstractQueuedSynchronizer的介绍和原理分析
查看>>
python socket 原汁原味代码
查看>>
Kubernetes的service mesh——第一部分:Service的重要指标
查看>>
全链路监控
查看>>
我的友情链接
查看>>
我的IT博客之路
查看>>
深入理解javascript原型和闭包(10)——this
查看>>
系统集成资质培训-论文写作-几个题目如何写?(updated)
查看>>