目录

1 Linux I/O模型

2 Linux I/O模型分类

3 Tomcat支持的I/O模型

4 Tomcat I/O模型选型

5 Tomcat NIO实现

6 Tomcat异步IO实现


1 Linux I/O模型
  • I/O:在计算机内存和外部设备之间拷贝数据的过程
  • 程序通过cpu向外部设备发出读指令,数据从外部设置拷贝至内存需要一段时间,这段时间cpu是空闲的,此时程序会有两种选择:
    • 让出cpu资源,让其干其他事
    • 继续让cpu不停地查询数据是否拷贝完成
  • 采用哪种策略就是I/O模型需要解决的事

  • 一个进程的地址空间分为用户空间和内核空间
  • 用户程序只能访问用户空间,内核进程可以访问整个进程空间
  • 只有内核才可以直接访问各种硬件资源,比如磁盘和网卡
  • 当cpu从网络读取数据时,分为两个阶段
    • 数据准备阶段:将数据从网卡拷贝到内核空间
    • 数据拷贝阶段:将数据从内核空间拷贝到用户空间
  • 不同的I/O模型对以上两个步骤有不同的实现

2 Linux I/O模型分类
  • 同步阻塞I/O
  • 同步非阻塞I/O
  • I/O多路复用
  • 信号驱动式I/O
  • 异步I/O

  • 阻塞或非阻塞是指应用程序在发起I/O操作时,是立即返回还是等待
  • 同步异步应用程序内核通信数据内核空间应用空间拷贝内核主动发起还是应用程序

java支持I/O模型同步阻塞I/OI/O多路复用异步I/O

3 Tomcat支持的I/O模型

tomcat支持I/O模型

IO模型

描述

BIO(BioEndpoint)

同步阻塞IO

模式下每个请求都会占用一个线程性能开销大不适合高并发场景

但是稳定适合连接数目并且固定架构

NIO(NioEndpoint)

IO多路复用

tomcat8之后默认采用IO模型

NIO方式适合连接数并且连接比较架构

AIO(Nio2Endpoint)

异步非阻塞IO

启动执行处理连接方法此时直接返回

发生连接事件执行回调方法完成连接

然后执行处理事件方法也是直接返回

当发生事件执行对应回调方法

适用于连接较多连接事件较长应用

APR(AprEndpoint)

Apache Portable RuntimeApache HTTP服务支持

AprEndpoint通过JNI调用APR本地而实现非阻塞IO

使用需要编译安装APR

Linux内核没有完善支持异步IO模型

因此JVM并没有采用原生Linux异步IO而是应用通过epoll模拟了异步IO模型

所以Linux平台Java NIOJava NIO2底层都是通过epoll来实现

4 Tomcat I/O模型选型
  • IO调优实际上连接器类型选择
  • 一般情况默认都是NIO
  • web应用启用TLS加密传输并且要求极高考虑使用APR
  • APR通过openssl来处理TLS握手openssl本身采用c语言开发并且TLS通信做了优化所以性能java要高
  • 如果tomcat运行windows平台并且http请求数据量较大考虑采用NIO2
  • windows操作系统平面实现真正意义异步IO如果传输数据量较大异步IO效果就能显现出来
  • tomcat运行linux平台建议使用NIOlinux平台nionio2都是通过epoll来实现但是nio简单高效
  • 指定IO模型修改Connector标签protocol属性
5 Tomcat NIO实现
  • tomcatEndpoint组件主要工作就是处理I/O
  • NioEndpoint利用java NIO API实现多路复用I/O模型
  • NioEndpoint基于主从Reactor多线程模型设计的
  • LimitLatch连接控制器负责控制最大连接数默认8192连接达到最大阻塞线程,直到后续组件处理一个连接连接数1
  • 到达最大连接数操作系统底层还是会接受客户端连接但是用户已经不在接收
  • Acceptor跑在一个单独线程死循环调用acceptor方法新连接一旦新的连接请求到来accept方法返回一个Channel对象Channel帝乡交给Poller去处理
  • Poller也跑单独线程Poller内部维护一个SelectorAcceptor传递过来Channel注册Selector读事件一旦发生事件生成一个SockeProcessor任务对象扔给Executor处理
  • Executor就是线程池负责运行SockeProcessor任务SockeProcessorrun方法调用Http11Processor来读取解析请求数据Http11Processor应用协议封装负责调用容器获得响应并将响应通过Channel写出
6 Tomcat异步IO实现

  • NIONIO2最大区别NIO2异步
  • 异步不需要应用程序自己触发数据内核空间用户空间拷贝
  • NioEndPoint没有Poller组件也就是没有Selector
  • 异步I/O模式下Selector工作交给内核来做了

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最新Spring Security实战教程企业级安全方案设计实现

最新Spring Security实战教程(十七)企业级安全方案设计 - 多因素认证(MFA)实现 1. 前言2. 为什么需要多因素认证? 传统认证的风险MFA的核心优势常见多因素认证实现方案 3. 多因素认证的核心原理4. 系统架构与流程设计…

十九、【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建

【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建 前言准备工作第一部分:回顾 Django 内置的 `User` 模型第二部分:设计并创建 `Role` 和 `UserProfile` 模型第三部分:创建 Serializers第四部分:创建 ViewSets第五部分:注册 API 路由第六部分:后端初步测…

大话软工笔记—架构的概要设计

架构的概要设计是在需求工程分析成果的基础之上对整个系统进行的顶层规划,重点是确定设计规范(理念、主线等),从大的范围和高度对业务进行规划和设计,架构概要设计的成果“业务架构图”,是后续各阶段设计的…

Flink CDC —部署模式

一、Standalone 模式 独立模式是Flink最简单的部署模式。本简短指南将向您展示如何下载最新稳定版本的Flink,安装和运行它。 您还将运行一个示例Flink CDC作业,并在web UI中查看它。 1、准备 Flink在所有类似UNIX的环境中运行,即Linux、Mac…

day029-Shell自动化编程-计算与while循环

文章目录 1. read 交互式初始化变量1.1 案例-安装不同的软件1.2 案例-比较大小 2. 计算2.1 bc2.2 awk2.3 expr2.4 let2.5 案例-计算内存的空闲率2.6 案例-检查域名过期时间和https证书过期时间 3. 循环3.1 循环控制语句3.2 for循环-c语言格式3.3 while循环3.3.1 案例-猜数字3.3…

华为云Flexus+DeepSeek征文 | 基于华为云ModelArts Studio打造AingDesk AI聊天助手

华为云FlexusDeepSeek征文 | 基于华为云ModelArts Studio打造AingDesk AI聊天助手 引言一、ModelArts Studio平台介绍华为云ModelArts Studio简介ModelArts Studio主要特点 二、安装AingDesk应用AingDesk应用介绍下载地址安装AingDesk工具 三、开通DeepSeek-R1-0528商用服务访问…

深度解析Git错误:`fatal: detected dubious ownership in repository` 的根源与解决方案

如果你是在使用自己的移动硬盘(U盘)操作项目时遇到的这个问题直接执行git config --global --add safe.directory X:/path即可,只要你的移动硬盘(U盘)没有病毒就不会有安全问题。 深度解析Git错误:fatal: d…

基于Spring Boot的校园社区平台设计与实现

目录 一.🦁前言二.🦁开源代码与组件使用情况说明三.🦁核心功能1. ✅算法设计2. ✅Thymeleaf模板引擎3. ✅MyBatis Plus框架4. ✅部署项目 四.🦁演示效果1. 管理员模块1.1 用户管理1.2 浏览管理员首页1.3 论坛管理1.4 校园咨询管理…

Java 8 Map 新增方法详解

Java 8 Map 新增方法详解 1. getOrDefault 源码: default V getOrDefault(Object key, V defaultValue) {V v;return (((v get(key)) ! null) || containsKey(key))? v: defaultValue;}作用:安全获取值,若key不存在则返回默认值 示例&…

山东大学 2025 web数据管理期末复习总结

SDU-2025年-Web数据管理期末总结 考试题型 填空 :都来自于PPT中名词解释简答题:需要背一些公式。 根据L老师上课提及的重点一共总结了87问题。 文章目录 SDU-2025年-Web数据管理期末总结考试题型第1讲 绪论此章不考 第2讲 网络爬虫技术2.1 爬虫是什么…

Spring框架的设计模式

Spring 框架深度集成了多种经典设计模式,这些模式支撑了其核心功能(如IoC、AOP)的实现,以下是关键模式及其应用场景的梳理: 1、工厂模式 工厂模式(Factory Pattern)是 Java 中最常用的设计模式…

git报错fatal: 远端意外挂断了

git报错fatal: 远端意外挂断了 报错详细内容 mr.mbogon tinymce % git add . mr.mbogon tinymce % git commit -m init [master c6cfc2a] init1 file changed, 2 insertions(), 1 deletion(-) mr.mengbogon tinymce % git push 枚举对象中: 241, 完成…

Windows 下安装 NVM

NVM 下载 NVM 在工作中,你可能遇到过某个项目需要高版本的 node 才能运行,而有的项目可能只支持低版本的 node,此时就可以借助于一些 Node 版本管理工具,比如 nvm(Node Version Manager),帮助…

AI知识补全(十七):通用人工智能AGI是什么?

名人说:博观而约取,厚积而薄发。——苏轼《稼说送张琥》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 上一篇:AI知识补全(十六):A2A - 谷歌开源的agent通信协议是什么? 目录 一、什么是AGI?概念解析1. 什么是AGI2. AGI与现有AI的本质区别二 、AGI的核…

Spring Cloud Gateway 介绍

什么是Spring Cloud Gateway? Spring Cloud Gateway 是 Spring Cloud 社区官方推出的一个基于 Spring Framework 5、Project Reactor 和 Spring Boot 2.x 的下一代 API 网关(API Gateway)解决方案。它旨在为微服务架构提供统一、简洁、高效的…

slam--高斯分布

教程 博主解释 高斯分布 高斯分布(Gaussian Distribution),又称正态分布(Normal Distribution),是描述连续型随机变量分布规律的一种概率分布。 (1) 一维高斯分布 μ:均值/数学期望&#xff0…

机器视觉标定讲解

B站 :道传科技上位机 观看教程 一、什么是相机标定 相机标定(Camera Calibration)是指通过实验或算法手段确定相机的内部参数(如焦距、主点坐标、畸变系数)和外部参数(如旋转矩阵、平移向量&#xff0…

文件的秒传、分片上传以及断点续传 || Redis缓存减轻数据库读写压力

实现文件的秒传、分片上传以及断点续传的功能。使用 Redis 缓存上传的文件分片信息减轻数据库读写压力,同时防止有人恶意攻击服务器导致服务器磁盘爆满无法提供服务。 🔍 详解: 1. 实现文件的秒传、分片上传以及断点续传功能 秒传&#xff0…

安全大模型智驱网络和数据安全效能跃迁

从2023年ChatGPT开始,网络安全行业就一直尝试和AI大模型来结合,解决网络安全的痛点,例如告警多,专家少,新的APT攻击层出不穷,已有的基于规则的防护手段失灵,如何使用大模型的泛化能力来提升对未…

Android S - 恢复部分应用安装

使用展锐提供的代码编译出来的固件&#xff0c;不包含DeskClock等应用。 之前也遇到过这个情况&#xff0c;只是时间太久忘记了&#xff0c;在这里再次记录&#xff01; frameworks/native/data/etc/android.app.remove.xml<?xml version"1.0" encoding"ut…