服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

云服务器|WEB服务器|FTP服务器|邮件服务器|虚拟主机|服务器安全|DNS服务器|服务器知识|Nginx|IIS|Tomcat|

服务器之家 - 服务器技术 - Tomcat - Tomcat怎么实现异步Servlet

Tomcat怎么实现异步Servlet

2021-08-17 16:56seaboat 汪洋之舟 Tomcat

这篇文章主要介绍了Tomcat怎么实现异步Servlet,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧。

有时servlet在生成响应报文前必须等待某些耗时的操作,比如在等待一个可用的jdbc连接或等待一个远程web服务的响应。对于这种情况servlet规范中定义了异步处理方式,由于servlet中等待阻塞会导致web容器整体的处理能力低下,所以对于比较耗时的操作可以放置到另外一个线程中进行处理,此过程保留连接的请求和响应对象,在处理完成之后可以把处理的结果通知到客户端。

下面先看servlet在同步情况下的处理过程,如图所示,tomcat的客户端请求由管道处理最后会通过wrapper容器的管道,这时它会调servlet实例的service方法进行逻辑处理,处理完后响应客户端,整个处理由tomcat的executor线程池的线程处理,而线程池的最大线程数使有限制的,所以这个处理过程越短、越快把线程让回线程池就越好。但如果servlet中的处理逻辑耗时越长就会导致长期地占用tomcat的处理线程池,影响tomcat的整体处理能力。

Tomcat怎么实现异步Servlet

为了解决上面的问题引入了支持异步的servlet,同样是客户端请求到来,然后通过管道最后进入到wrapper容器的管道,调用servlet实例的service后,创建一个异步上下文将耗时的逻辑操作封装起来,交给用户自己定义的线程池,这时tomcat的处理线程就能马上回到executor线程池,而不用等待耗时的操作完成才让出线程,从而提升了tomcat的整体处理能力。这里要注意的是,由于后面做完耗时的操作后还需要对客户端响应,所以需要保持住request和response对象,以便输出响应报文到客户端。

Tomcat怎么实现异步Servlet

再结合一个简单的异步代码来看tomcat对servlet异步的实现:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
public class asyncservlet extends httpservlet {
 
  scheduledthreadpoolexecutor userexecutor = new scheduledthreadpoolexecutor(5);
 
  public void doget(httpservletrequest req, httpservletresponse res) {
    asynccontext actx = req.startasync(req, res);
    userexecutor.execute(new asynchandler(actx));
  }
 
}
 
public class asynchandler implements runnable {
 
  private asynccontext ctx;
 
  public asynchandler(asynccontext ctx) {
    this.ctx = ctx;
  }
 
  @override
  public void run() {
    //耗时操作
    printwriter pw;
    try {
      pw = ctx.getresponse().getwriter();
      pw.print("done!");
      pw.flush();
      pw.close();
    } catch (ioexception e) {
      e.printstacktrace();
    }
    ctx.complete();
  }
}

我们创建一个asyncservlet,它定义了一个userexecutor线程池专门用于处理该servlet的所有请求的耗时的逻辑操作。这样就不会占用tomcat内部的executor线程池,影响到对其他servlet的处理。这种思想有点像资源隔离,耗时的操作统一由指定的线程池处理,而不要影响其它耗时少的请求处理。

servlet的异步的实现就很好理解了,startasync方法其实就是创建了一个异步上下文asynccontext对象,该对象封装了请求和响应对象。然后创建一个任务用于处理耗时逻辑,后面通过asynccontext对象获得响应对象并对客户端响应,输出“done!”。完成后要通过complete方法告诉tomcat内部我已经处理完,tomcat就会请求对象和响应对象进行回收处理或关闭连接。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/wangyangzhizhou/article/details/53207966

延伸 · 阅读

精彩推荐
  • Tomcat解决Tomcat10 Catalina log乱码问题

    解决Tomcat10 Catalina log乱码问题

    这篇文章主要介绍了解决Tomcat10 Catalina log乱码问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的...

    条卯李系瓜皮10672021-09-17
  • TomcatTomcat日志文件定时清理备份的脚本

    Tomcat日志文件定时清理备份的脚本

    这篇文章主要介绍了Tomcat日志文件定时清理备份的脚本的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下...

    jaamy8492021-08-15
  • TomcatTomcat核心组件及应用架构详解

    Tomcat核心组件及应用架构详解

    众所周知Tomcat 就是一个 Servlet 容器,为了方便使用,他们具有http服务器的功能,所以Tomcat 就是一个“HTTP 服务器 + Servlet 容器”,我们也叫它们 Web 容器,...

    PoetryAndTheDistance12612021-09-24
  • TomcatCentOS系统下安装Tomcat7的过程详解

    CentOS系统下安装Tomcat7的过程详解

    今天开始学习Tomcat7 ,学习前首先需要安装,我用的系统是CentOS系统,所以下面这篇文章主要介绍了CentOS系统下安装Tomcat7的过程,需要的朋友可以参考下,下...

    上品物语5902021-08-16
  • Tomcat如何在IntelliJ IDEA 2018上配置Tomcat并运行第一个JavaWeb项目

    如何在IntelliJ IDEA 2018上配置Tomcat并运行第一个JavaWeb项目

    这篇文章主要介绍了在IntelliJ IDEA 2018上配置Tomcat并运行第一个JavaWeb项目,需要的朋友可以参考下...

    「已注销」4242021-09-15
  • TomcatMac+IDEA+Tomcat配置的方法步骤

    Mac+IDEA+Tomcat配置的方法步骤

    本主要介绍了Mac+IDEA+Tomcat配置的方法步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    海M滨8062021-11-14
  • Tomcattomcat的配置使用详细版(小结)

    tomcat的配置使用详细版(小结)

    开发者开发部署web应用时通常使用tomcat服务器,这篇文章主要介绍了tomcat的配置使用详细版(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参...

    yumiaoxa5592021-08-31
  • Tomcatidea打包成war包部署到tomcat及访问路径问题(图文详解)

    idea打包成war包部署到tomcat及访问路径问题(图文详解)

    这篇文章主要介绍了idea打包war包部署到tomcat以及访问路径问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴...

    Ma_Bu_Teng7952021-09-12