Tomcat 线程池

news2025/1/10 10:15:54

目录

概述

tomcat线程池工作原理

关键源码

Connector 配置 

 Executor 线程配置

 tomcat核心组件(题外)


概述

Tomcat 是一个流行的 Java Web 服务器,它使用线程池来处理客户端请求。线程池是一组预先创建的线程,用于执行并发任务,以提高性能和资源利用率。

在 Tomcat 中,线程池被用来处理传入的 HTTP 请求。当客户端发送请求时,Tomcat 会从线程池中获取一个可用的线程来处理该请求。处理完请求后,线程将返回线程池,并在下一个请求到来时再次被重用。

Tomcat 的线程池配置可以通过编辑 server.xml 文件来进行。以下是一些常见的线程池配置选项:

  1. maxThreads:指定线程池中的最大线程数。这决定了 Tomcat 能同时处理的最大请求数量。
  2. minSpareThreads:指定线程池中的最小空闲线程数。当请求量较小时,线程池中的线程数量可以减少到此值以下。
  3. maxIdleTime:指定线程在空闲状态下保持活动的最长时间。超过该时间后,线程将被终止并从线程池中移除。
  4. acceptCount:指定等待队列的最大长度。当所有线程都在忙碌时,新的请求将被放置在等待队列中。
tomcat线程池工作原理

Tomcat 的线程池工作原理如下:

  1. 初始化线程池:在 Tomcat 启动时,会初始化线程池,并创建一定数量的线程。

  2. 接收请求:当客户端发起请求时,Tomcat 的连接器将接收到请求,并将其传递给线程池。

  3. 线程池调度:线程池中的线程会被调度来处理请求。如果线程池中有空闲线程,将会有一个线程去执行该请求。如果线程池中没有可用线程,请求将进入等待队列。

  4. 请求处理:选中的线程会处理请求,包括解析请求、执行相应的业务逻辑等。该线程会一直处理请求直到完成。

  5. 请求完成:处理完请求后,线程将返回到线程池中,变为可用状态,以供处理下一个请求。

  6. 等待队列:如果线程池中没有空闲线程,新到达的请求将会进入等待队列。请求按照先到先服务的顺序排队等待处理。等待队列的长度由 acceptCount 参数决定。

  7. 线程重用:线程池中的线程会被重复使用,避免了频繁创建和销毁线程的开销。这样可以提高性能,并降低资源消耗。

  8. 线程管理:线程池还负责管理线程的生命周期,包括创建、销毁和维护线程的状态。

这里的空闲线程指 最大线程,即如果核心线程为2,最大线程为3,但现在来了3个任务,tomcat的线程池会创建一个救急线程来执行第三个任务,并不回加入队列。这个点跟普通线程池不一样。

总结:

提交任务数小于核心线程数,则创建任务数的线程;

当前线程数达到核心线程数,调用任务队列方法;

当前线程数达到最大线程数,默认放入任务队列;

提交任务数小于等于当前线程,表明还有空闲线程,无需创建线程;

提交任务数大于当前线程数小于最大线程数,重写任务队列的offer方法返回false不执行默认的放入队列操作,继续创建线程(false表示任务队列已满);

提交任务数达到任务队列最大值,执行拒绝策略。

关键源码
public void execute(Runnable command, long timeout, TimeUnit unit) {
	//这个字段是记录的线程提交的数量,如果线程执行完毕,这个字段会减1 
	submittedCount.incrementAndGet();
	try {
	//执行jdk的线程池代码
		super.execute(command);
	} catch (RejectedExecutionException rx) {
	//拒绝策略,发生的情况是线程超过最大值(maxThreads),并且队列也已经满了,也就是(Integer.MAX+maxThreads)
		if (super.getQueue() instanceof TaskQueue) {
			final TaskQueue queue = (TaskQueue)super.getQueue();
			try {
			//这里其实就是讲这个线程(60s后)丢到队列里面,如果60s后队列还是满的,那就没办法了,抛异常……
				if (!queue.force(command, timeout, unit)) {
					submittedCount.decrementAndGet();
					throw new RejectedExecutionException(sm.getString("threadPoolExecutor.queueFull"));
				}
			} catch (InterruptedException x) {
				submittedCount.decrementAndGet();
				throw new RejectedExecutionException(x);
			}
		} else {
			submittedCount.decrementAndGet();
			throw rx;
		} 
	}
}

 TaskQueue.java

public boolean force(Runnable o, long timeout, TimeUnit unit) throws InterruptedException {
 if ( parent.isShutdown() ) 
     throw new RejectedExecutionException(
     "Executor not running, can't force a command into the queue"
 );
//forces the item onto the queue, to be used if the task is rejected
 return super.offer(o,timeout,unit); 
}
Connector 配置 

 Executor 线程配置

 tomcat核心组件(题外)

它由多个核心组件组成,这些组件共同协作来实现对 Web 应用程序的处理和管理。以下是 Tomcat 的一些核心组件:

  1. 连接器(Connector):连接器负责接收客户端的 HTTP 请求,并将其传递给 Tomcat 进行处理。Tomcat 支持多种类型的连接器,如 HTTP 连接器、AJP(Apache JServ Protocol)连接器等。

  2. 引擎(Engine):引擎是 Tomcat 的顶层容器,它负责管理和协调多个虚拟主机(Host)的处理过程。每个引擎都有自己的生命周期和一组关联的虚拟主机。

  3. 虚拟主机(Host):虚拟主机用于托管多个 Web 应用程序。每个虚拟主机都有自己的域名或 IP 地址,并可以独立配置和管理自己的 Web 应用程序。

  4. 上下文(Context):上下文代表一个 Web 应用程序,它包含了应用程序的配置信息、Servlet、过滤器、监听器等。Tomcat 可以同时运行多个上下文,每个上下文都有唯一的上下文路径。

  5. Servlet 容器(Servlet Container):Servlet 容器负责加载、初始化和管理 Servlet。它提供了与 Servlet 相关的生命周期管理、请求处理和响应生成等功能。

  6. JSP 引擎(JSP Engine):JSP 引擎用于将 JSP(JavaServer Pages)文件转换为 Java 代码,并编译成 Servlet。Tomcat 使用 Jasper 作为默认的 JSP 引擎来处理 JSP 页面。

  7. 管理器(Manager):管理器负责管理和维护 Web 应用程序的会话(Session)。它可以跟踪会话的创建和销毁,以及提供会话的持久化和集群支持。

以上是 Tomcat 的一些核心组件,它们共同构成了 Tomcat 的基本架构,使其能够运行和管理 Java Web 应用程序。每个组件都承担着不同的职责和功能,相互配合,完成对 Web 应用程序的处理和服务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/734509.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FreeRTOS ~(七)互斥量 ~ (1/3)互斥量解决互斥缺陷

前情提要 FreeRTOS ~(四)同步互斥与通信 ~ (2/3)互斥的缺陷 FreeRTOS ~(五)队列的常规使用 ~ (2/5)队列解决互斥缺陷 FreeRTOS ~(六)信号量 ~ (2/…

Android Camera2 获取RAW数据

这边文章主要记录下在Android系统上,如何通过Camera2 API去拿到RAW数据,也是当个备忘。 平时我们拿实时预览数据,更多的是获取yuv数据。一般涉及到raw域算法在APP层实现的时候,我们才会用到获取raw数据。 APP上集成Raw算法的思路…

【CSDN新星计划】初阶牛C/C++赛道——顺序程序设计(运算符和表达式)

目录 🍉2.运算符和表达式 2.1 C运算符 2.2基本的算术运算符 2.3自增( )自减( - - )运算符 2.4算术表达式和运算符的优先级与结合性 2.运算符和表达式 2.1 C运算符 C语言提供了以下运算符: (1)算术…

印度反垄断机构偏袒亚马逊,谷歌对滥用安卓市场地位罚款提出质疑

根据路透社消息,谷歌指控印度反垄断机构在其安卓系统调查中对亚马逊持偏袒态度,并向印度最高法院提起诉讼,对其关于滥用安卓市场地位的罚款提出质疑。 印度竞争委员会(CCI)最近要求谷歌改变商业模式,称谷歌…

结合具体场景举例说明chatgpt预训练模型中Tokenization的原理

假设我们有一个场景,Alice想向Chatbot询问一部电影的推荐。她发送了一条消息:“你好,能给我推荐一部好看的电影吗?” 在这个场景中,Chatbot使用了ChatGPT预训练模型。首先,Chatbot需要对Alice的消息进行Tok…

【力扣周赛】第 108 场双周赛

文章目录 Q1:6913. 最长交替子序列思路竞赛时代码代码优化 Q2:6469. 重新放置石块思路竞赛时代码 Q3:6923. 将字符串分割为最少的美丽子字符串解法1—— dfs回溯 剪枝 判断解法2——动态规划 Q4:6928. 黑格子的数目代码优化 成绩…

Jenkins持续集成

文章目录 Jenkins介绍Jenkins的特征 Jenkins架构Gitlab安装1. Gitlab代码托管服务器安装2. Gitlab添加组、创建用户、创建项目 jenkins安装安装JenkinsJenkins插件管理Jenkins用户权限管理Jenkins凭证管理安装Git插件和Git工具设置SSH免密登录 Maven安装和配置JenkinsDockerspr…

【数据结构】栈和队列详解

⭐️ 往期相关文章 ✨链接1:数据结构和算法的概念以及时间复杂度空间复杂度详解 ✨链接2:【数据结构】手撕顺序表 ✨链接3:【数据结构】手撕单链表 ✨链接4:【数据结构】双向带头循环链表 ⭐️ 栈和队列 🌠 栈 栈是…

react-native项目手机预览

初始化项目 使用 expo 初始化 react-native 项目,https://reactnative.cn/docs/environment-setup 运行项目 执行 start 命令运行项目 拿起你的iPhone手机,安装 expo APP,https://expo.dev/client 或者到 APP store 搜索下载。下载完成之…

基于TCP协议的聊天系统TCP-ChatSystem

基于TCP协议的点对点聊天系统 网络协议:TCP 聊天形式:点对点 所用技术:socket、多路转接、线程池、互斥锁、条件变量、MFC等。 功能点:注册、登录、添加好友、聊天等。 实现示意图 客户端登陆注册消息流转图: 客…

【MATLAB第54期】基于LSTM长短期记忆网络的多输入多输出滑动窗口回归预测模型

【MATLAB第54期】基于LSTM长短期记忆网络的多输入多输出滑动窗口回归预测模型 往期第13期已实现多输入单输出滑动窗口回归预测 本次在此代码基础上,新增多输出滑动窗口功能。 多输入单输出滑动窗口回归预测 一、实现效果 往期文章提到了对单列时间序列数据进行滑…

spdlog入门教程(1)

spdlog入门教程(1) 文章目录 spdlog入门教程(1)1、前言1.1 为什么要使用日志库1.2 尽量使用通用日志框架而不要自己实现1.3 spdlog概述1.4 地址 2、源码编译配置spdlog3、在Qt中使用spdlog1.1 验证spdlog是否配置成功1.2 将日志输…

全网最牛,Pytest自动化测试-pytest.mark.parametrize参数化实战(详细)

目录:导读 前言 一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 pytest允许在多个…

删除数据库记录错误

删除数据库记录错误:Unexpected update count received (Actual: 2, Expected: 1). All changes will be rolled back. 解决:同时删掉ID为8的记录就行了 分析:这种情况是未设置主键约束,插入了相同的记录导致的。推测应该是框架对…

Clip-Path

前言 借助clip-path,我们可以实现一些复杂的animation动画效果,我们先来简单概述一下它的特性,如MDN所描述的。 The clip-path CSS property creates a clipping region that sets what part of an element should be shown. Parts that are inside the region are shown, whi…

基于aarch64分析kernel源码 一:环境搭建

一、测试环境 功能工具操作系统ubuntu 22.04编译工具gcc-12-aarch64-linux-gnu调试工具gdb-multiarch模拟器qemu 6.2.0busyboxbusybox-1.36.1kernellinux-6.4.1编辑器vscode 二、编译器 1、查找ubuntu仓库中aarch64编译器 lqlq-virtual-machine:~/my$ apt-cache search aar…

零矩阵

暴力解法:先全部检索,定位0所在的位置, 记录到新的数组 数组的行列分别进行去重 数组中记录的行列赋值为零 如果直接修改,在行被修改之后,修改列时会因为行已经被修改产生影响 import org.junit.Test;import java.uti…

tensorboard命令行使用方法

第一步:进入虚拟环境 conda activate 虚拟环境名称 第二步: tensorboard --logdir绝对地址 第三步:在浏览器输入提供的网址

day03 重新学python——python函数

文章目录 一、python函数1.函数介绍2.函数的定义3.函数的参数4.函数的返回值5.函数的说明文档6.函数的嵌套调用7.变量的作用域8.综合案例 一、python函数 1.函数介绍 函数:即组织好的、课重复利用,用来实现特殊功能的代码段,这样可以提高代码…

生产者消费者

前言 生产者消费者模式属于一种经典的多线程协作的模式,弄清生产者消费者问题能够让我们对于多线程编程有更深刻的理解,下面,为大家分享一个生产者消费者的案例。 一、案例描述 这里以快递为例,假设有一个快递柜,用来…