0

0

Java中Apache在Event架构下监听线程与工作线程协作

冷炫風刃

冷炫風刃

发布时间:2026-03-13 13:38:03

|

292人浏览过

|

来源于php中文网

原创

Apache HTTP Server 用 C 编写,不涉及 Java;文中所述“Event 架构”实指 Tomcat 的 NIO/NIO2 事件驱动模型,其通过 Acceptor、Poller 和 Executor 线程分工实现非阻塞 I/O 与业务逻辑解耦。

apache http server 本身是用 c 编写的,不直接使用 java 或 jvm;你提到的“java 中 apache 在 event 架构下监听线程与工作线程协作”,实际指向的很可能是 apache tomcat(java web 容器),尤其是其基于 nio/nio2 的 apr/native 或 nio2 connector 配置下的事件驱动模型(即 “event” protocol,已从 tomcat 8.5+ 起逐步被 nio2 取代,但概念仍适用)。

Tomcat 的 event 协议本质是 Reactor 模式

在旧版 Tomcat(如 7.x)中启用 protocol="org.apache.coyote.http11.Http11Protocol" 并配合 executor 时,默认是阻塞 I/O(BIO);而启用 protocol="org.apache.coyote.http11.Http11NioProtocol"(或更早的 Http11NioProtocol + useSendfile="false")并设置 maxThreadsacceptorThreadCount,就进入了典型的“监听-事件分发-工作执行”协作模型:

  • 监听线程(Acceptor):由 acceptorThreadCount 控制(默认 1),只负责调用 ServerSocketChannel.accept(),获取新连接的 SocketChannel,然后立即注册到共享的 Selector 上,不处理请求内容。
  • 事件轮询线程(Poller):每个 Poller 是一个独立线程,持有专属 Selector,持续调用 select() 检测就绪事件(如 OP_READ、OP_WRITE)。一旦发现某 channel 可读,就将该 channel 封装为 SocketProcessor 任务,提交给共享线程池。
  • 工作线程(Executor Thread):来自配置的 Executor(如 org.apache.catalina.core.StandardThreadExecutor),真正解析 HTTP 请求、调用 Servlet、生成响应。它不参与 I/O 等待,纯 CPU/业务逻辑处理。

关键协作机制:避免阻塞,解耦 I/O 与业务

这种分工的核心目标是防止慢请求(如数据库查询、远程调用)阻塞 I/O 处理能力:

  • Acceptor 不做 read/write,不解析协议,秒级完成 accept 后交出 channel。
  • Poller 不做业务处理,只做轻量事件识别和任务投递;即使某个请求 body 很大,也只在 channel 可读时触发一次投递,后续由工作线程循环 read(或借助 ReadListener 异步流式读取)。
  • 工作线程若需异步响应(如长轮询、SSE),可调用 request.startAsync(),释放当前线程,后续通过 AsyncContext 派发回调,避免线程长期占用。

配置示例(server.xml 中 Connector)

以下是一个典型 NIO2(推荐替代旧 event)的配置,体现监听与工作分离:

Nanonets
Nanonets

基于AI的自学习OCR文档处理,自动捕获文档数据

下载
<Connector port="8080"
    protocol="org.apache.coyote.http11.Http11Nio2Protocol"
    maxThreads="200"
    minSpareThreads="10"
    acceptorThreadCount="2"
    pollerThreadCount="4"
    connectionTimeout="20000"
    redirectPort="8443" />

其中:
acceptorThreadCount="2":2 个线程争抢 accept 权限(适合高并发端口复用场景);
pollerThreadCount="4":4 个 Selector 轮询线程,分摊事件检测压力;
maxThreads="200":最多 200 个工作线程处理请求逻辑。

注意:Tomcat 9+ 已弃用独立 event 协议

早期 Tomcat 7 的 Http11AprProtocol(基于 APR/native 库)曾提供真正的 event 模型(epoll/kqueue),但 Java 层统一抽象后,NIO2 Connector 已成为标准。所谓“event 架构”现在更多指代这种非阻塞、多线程协作的 I/O 处理范式,而非某个特定 protocol 名称。开发中应优先使用 Http11Nio2Protocol 并合理调优线程数,而非寻找已移除的 event 配置。

立即学习Java免费学习笔记(深入)”;

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

99

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

158

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号