iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Tomcat处理请求的线程模型是什么
  • 881
分享到

Tomcat处理请求的线程模型是什么

2023-06-29 16:06:57 881人浏览 安东尼
摘要

小编给大家分享一下Tomcat处理请求的线程模型是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、前言JAVA后端项目,运行在容器tomcat中,由于现在S

小编给大家分享一下Tomcat处理请求的线程模型是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

    一、前言

    JAVA后端项目,运行在容器tomcat中,由于现在SpringBoot的内置tomcat容器,其默认配置屏蔽了很多对tomcat的认知,但是对tomcat的学习和认识是比较重要的,所以专门查资料加深了理解,本文主要讨论在springboot集成下的tomcat9的请求过程,线程模型为NIO

    二、tomcat结构

    Tomcat处理请求的线程模型是什么

    找了张结构图,每个模块的意思和作用就不详解了,可以搜其他文章

    三、探讨tomcat是如何处理请求

    Tomcat处理请求的线程模型是什么

    自己画了一个connector的结构

    1、初始化

    在springboot启动后,org.springframework.context.support.AbstractApplicationContext#finishRefresh,这里进去调用org.springframework.boot.WEB.servlet.context.WebServerStartStopLifecycle.start()方法启动TomcatWebServer,初始化tomcat。

    Tomcat处理请求的线程模型是什么

    Tomcat处理请求的线程模型是什么

    通过这样的调用链到达org.apache.tomcat.util.net.NioEndpoint#startInternal(),进行初始化Endpoint中的AcceptorPoller,这两者都实现了Runnable接口,初始化后就通过线程start启动了。

    2、如何处理客户端请求

    Acceptor: 接收器,作用是接受scoket网络请求,并调用setSocketOptions()封装成为NiOSocketWrapper,并注册到Poller的events中。注意查看run方法org.apache.tomcat.util.net.Acceptor#run

     @Override    public void run() {        int errorDelay = 0;        try {            // Loop until we receive a shutdown command            while (!stopCalled) {                // Loop if endpoint is paused                while (endpoint.isPaused() && !stopCalled) {                    state = AcceptorState.PAUSED;                    try {                        Thread.sleep(50);                    } catch (InterruptedException e) {                        // Ignore                    }                }                if (stopCalled) {                    break;                }                state = AcceptorState.RUNNING;                try {                    //if we have reached max connections, wait                    endpoint.countUpOrAwaitConnection();                    // Endpoint might have been paused while waiting for latch                    // If that is the case, don't accept new connections                    if (endpoint.isPaused()) {                        continue;                    }                    U socket = null;                    try {                        // 等待下一个请求进来                        socket = endpoint.serverSocketAccept();                    } catch (Exception ioe) {                        // We didn't get a socket                        endpoint.countDownConnection();                        if (endpoint.isRunning()) {                            // Introduce delay if necessary                            errorDelay = handleExceptionWithDelay(errorDelay);                            // re-throw                            throw ioe;                        } else {                            break;                        }                    }                    // Successful accept, reset the error delay                    errorDelay = 0;                    // Configure the socket                    if (!stopCalled && !endpoint.isPaused()) {                        // 注册socket到Poller,生成PollerEvent事件                        if (!endpoint.setSocketOptions(socket)) {                            endpoint.closeSocket(socket);                        }                    } else {                        endpoint.destroySocket(socket);                    }                } catch (Throwable t) {                    ExceptionUtils.handleThrowable(t);                    String msg = sm.getString("endpoint.accept.fail");                    // APR specific.                    // Could push this down but not sure it is worth the trouble.                    if (t instanceof Error) {                        Error e = (Error) t;                        if (e.getError() == 233) {                            // Not an error on HP-UX so log as a warning                            // so it can be filtered out on that platfORM                            // See bug 50273                            log.warn(msg, t);                        } else {                            log.error(msg, t);                        }                    } else {                            log.error(msg, t);                    }                }            }        } finally {            stopLatch.countDown();        }        state = AcceptorState.ENDED;    }

    Poller:轮询器,轮询是否有事件达到,有请求事件到达后,以NIO的处理方式,查询Selector取出所有请求,遍历每个请求的需求,分配给Executor线程池执行。查看org.apache.tomcat.util.net.NioEndpoint.Poller#run()

     public void run() {            // Loop until destroy() is called            while (true) {                boolean hasEvents = false;                try {                    if (!close) {                        hasEvents = events();                        if (wakeupCounter.getAndSet(-1) > 0) {                            // If we are here, means we have other stuff to do                            // Do a non blocking select                            keyCount = selector.selectNow();                        } else {                            keyCount = selector.select(selectorTimeout);                        }                        wakeupCounter.set(0);                    }                    if (close) {                        events();                        timeout(0, false);                        try {                            selector.close();                        } catch (IOException ioe) {                            log.error(sm.getString("endpoint.nio.selectorCloseFail"), ioe);                        }                        break;                    }                    // Either we timed out or we woke up, process events first                    if (keyCount == 0) {                        hasEvents = (hasEvents | events());                    }                } catch (Throwable x) {                    ExceptionUtils.handleThrowable(x);                    log.error(sm.getString("endpoint.nio.selectorLoopError"), x);                    continue;                }//查询selector取出所有请求                Iterator<SelectionKey> iterator =                    keyCount > 0 ? selector.selectedKeys().iterator() : null;                // Walk through the collection of ready keys and dispatch                // any active event.                while (iterator != null && iterator.hasNext()) {                    SelectionKey sk = iterator.next();                    iterator.remove();                    NioSocketWrapper socketWrapper = (NioSocketWrapper) sk.attachment();                    //处理请求key                    if (socketWrapper != null) {                        processKey(sk, socketWrapper);                    }                }                // Process timeouts                timeout(keyCount,hasEvents);            }            getStopLatch().countDown();        }

    请求过程大致如下图:

    Tomcat处理请求的线程模型是什么

    以上是“Tomcat处理请求的线程模型是什么”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

    --结束END--

    本文标题: Tomcat处理请求的线程模型是什么

    本文链接: https://www.lsjlt.com/news/325621.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Tomcat处理请求的线程模型是什么
      小编给大家分享一下Tomcat处理请求的线程模型是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、前言JAVA后端项目,运行在容器tomcat中,由于现在s...
      99+
      2023-06-29
    • Tomcat处理请求的线程模型详解
      目录一、前言二、tomcat结构三、探讨tomcat是如何处理请求1、初始化2、如何处理客户端请求总结一、前言 JAVA后端项目,运行在容器tomcat中,由于现在springboo...
      99+
      2024-04-02
    • springmvc处理请求的流程是什么
      Spring MVC处理请求的流程如下:1. 客户端发送请求到DispatcherServlet,DispatcherServlet...
      99+
      2023-08-18
      springmvc
    • ASP.NET处理HTTP请求的流程是什么
      这篇文章主要介绍“ASP.NET处理HTTP请求的流程是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ASP.NET处理HTTP请求的流程是什么”文章能帮助大家解决问题。一、ASP.NET处理管...
      99+
      2023-06-30
    • Redis线程模型的原理是什么
      这篇文章主要介绍“Redis线程模型的原理是什么”,在日常操作中,相信很多人在Redis线程模型的原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis线程模型的原理是什么”的疑惑有所帮助!接下来...
      99+
      2023-06-21
    • Apache Tomcat怎么高并发处理请求
      这篇文章给大家分享的是有关Apache Tomcat怎么高并发处理请求的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。介绍作为常用的http协议服务器,tomcat应用非常广泛。tomcat也是遵循Ser...
      99+
      2023-06-29
    • Redis线程模型是什么
      这篇文章主要讲解了“Redis线程模型是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis线程模型是什么”吧! Redis它是一个单线程的,这一点需要去注意的。首先我们呢会有一个客...
      99+
      2023-06-30
    • SpringBoot监控Tomcat活动线程数来判断是否完成请求处理方式
      目录SpringBoot监控Tomcat活动线程数来判断是否完成请求处理编码实现测试Tomcat线程数占满而导致的线上事故事故表现形式排查过程分析原因解决办法总结SpringBoot...
      99+
      2023-02-28
      SpringBoot Tomcat SpringBoot监控 SpringBoot Tomcat线程数
    • 浏览器请求流程和PHP对请求的处理方法是什么
      这篇“浏览器请求流程和PHP对请求的处理方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“浏览器请求流程和PHP对请求...
      99+
      2023-07-05
    • SpringBoot怎么监控Tomcat活动线程数来判断是否完成请求处理方式
      这篇文章主要讲解了“SpringBoot怎么监控Tomcat活动线程数来判断是否完成请求处理方式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot怎么监控Tomcat活动线程...
      99+
      2023-07-05
    • php处理post请求的方法是什么
      在PHP中处理POST请求的方法是使用$_POST超全局变量来获取POST请求的数据。$_POST是一个关联数组,它包含了所有的PO...
      99+
      2023-10-10
      PHP
    • Node.js中的单线程模型是什么
      这期内容当中小编将会给大家带来有关Node.js中的单线程模型是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、高并发一般来说,高并发的解决方案就是多线程模型,服务...
      99+
      2024-04-02
    • Android中的单线程模型是什么
      这篇文章给大家介绍Android中的单线程模型是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Android 单线程模型详解及实例当第一次启动一个Android程序时,Android会自动创建一个称为“main”主...
      99+
      2023-05-31
      android 单线 roi
    • JavaServlet线程中AsyncContext异步处理Http请求
      目录AsyncContextAsyncContext使用示例及测试示例测试结果AsyncContext应用场景背景AsyncContext解决生产问题AsyncContext Asy...
      99+
      2023-03-01
      Java AsyncContext异步处理 Java Servlet AsyncContext
    • django异步请求处理的方法是什么
      Django中的异步请求处理可以通过以下几种方法实现:1. 使用Django的内置异步任务处理机制:Django提供了一个名为`as...
      99+
      2023-09-26
      Django
    • Redis中线程IO模型是什么
      这篇文章将为大家详细讲解有关Redis中线程IO模型是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Redis是一个单线程的应用程序,NodeJs、Nginx都是单线...
      99+
      2024-04-02
    • Nginx请求处理流程是怎样的
      这篇文章主要介绍“Nginx请求处理流程是怎样的”,在日常操作中,相信很多人在Nginx请求处理流程是怎样的问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Nginx请求处理流程是怎样的”的疑惑有所帮助!接下来...
      99+
      2023-06-04
    • postman模拟post请求的四种请求体分别是什么
      今天就跟大家聊聊有关postman模拟post请求的四种请求体分别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.application/x-www-form-urlenco...
      99+
      2023-06-26
    • ASP.NET的请求处理过程是怎样的
      这篇文章主要介绍“ASP.NET的请求处理过程是怎样的”,在日常操作中,相信很多人在ASP.NET的请求处理过程是怎样的问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ASP.NET的请求处理过程是怎样的”的疑...
      99+
      2023-06-17
    • ajax请求返回类型是什么
      这篇“ajax请求返回类型是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ajax请求...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作