码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 总结:Tomcat的IO模型


    一、介绍

    对于 linux 操作系统,IO 多路复用使用的是 epoll 方式,对于 windows 操作系统中 IO 多路复用使用的是 iocp 方式,对于 mac 操作系统 IO 多路复用使用的是 kqueue 方式。

    由于对于 tomcat 服务器来说基本主要部署在 linux 操作系统上,所以我们主要介绍 linux 的 epoll 模型。epoll 是 event poll 的简称,在 linux 内核版本 2.6 开始支持,所以如果你的 tomcat 服务器如果希望默认使用 NIO,除了自己版本在 tomcat7 以上之外,还需要部署在 linux 内核版本大于 2.6 的操作系统之上。

    二、BIO

    tomcat6 和之前的版本默认都是使用的 BIO 模型。

    BIO模型:即阻塞式IO。

    在TomcatBIO模型中,主要参与的角色有:Acceptor和Handler工作线程池。对应于前文中Api的请求过程,它们的分工如下:

    • Acceptor:Accepter线程专门负责建立网络连接(accept)。新连接创建后,交给Handler工作线程池处理请求。
    • Handlers:针对每个请求的连接,Handler工作线程池都会分配一个线程,执行后面的所有步骤(read、decode、process、encode、send)。

    三、NIO

    tomcat7之后(包含7),默认使用NIO模型,即非阻塞式IO,实现是基于JDK的java.nio包。

    tomcat的NIO模型,相比较于BIO模型,多了个Poller角色:Acceptor、Poller和Handler工作线程池。

    • Acceptor:Accepter线程专门负责建立网络连接(accept)。新连接创建后,不是直接使用Worker线程处理请求,而是先将请求发送给Poller缓冲队列。
    • Poller:在Poller中,维护了一个Selector对象,当Poller从缓冲队列中取出连接后,注册到该Selector中,阻塞等待读写就绪(read等待就绪、send等待就绪)。
    • Handlers:遍历Selector,找出其中就绪的IO操作,并交给Worker线程处理(read内存读、decode、process、encode、send内存写)。

    参考:

    NIO优化原理和Tomcat线程模型 - SegmentFault 思否

    Tomcat NIO(2)-epoll多路复用 - 腾讯云开发者社区-腾讯云

    Java面试题:Tomcat中BIO和NIO线程模型工作原理 - 简书

  • 相关阅读:
    Tauri+Vite+Vue3创建项目步骤
    云服务器安装elasticsearch 以及 kibana 附详细图文(全)
    Java I/O中的Reactor模式
    1.2 数据模型
    Lwip之ARP模块实现
    计算机毕业设计之java+ssm的校园旧书交易交换平台
    Shell脚本-for循环和for int循环
    Python 读取PostgreSQL的geometry字段时,获取geometry的中心点
    3分钟彻底搞懂Web UI自动化测试之【POM设计模式】
    【洛谷 P2678】[NOIP2015 提高组] 跳石头 题解(二分答案+循环)
  • 原文地址:https://blog.csdn.net/w2009211777/article/details/125542322
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号