linux的网络IO驱动模型

应用程序需要等待内核将数据从套接字缓冲区中复制到进程空间

当应用程序从套接字接收数据时,数据首先被复制到内核的套接字接收缓冲区中。然后,当应用程序调用类似于 read() 系统调用时,内核会将数据从套接字接收缓冲区复制到相应的应用程序的进程空间中。

网络 I/O 模型确实是根据数据在网络缓冲区和进程空间之间传输的具体步骤来划分的

阻塞 I/O

在阻塞 I/O 模型中,应用程序在进行 I/O 操作(read)时会被阻塞,直到数据从网络缓冲区复制到进程空间完成,内核返回响应。这意味着应用程序在等待 I/O 操作完成时无法执行其他任务。(会让出cpu)

非阻塞 I/O

非阻塞 I/O 模型允许应用程序在进行 I/O 操作时立即返回,而不必等待数据传输完成。

I/O 多路复用

I/O 多路复用模型通过一个系统调用(如 select()、poll()、epoll())同时监听多个套接字,通过阻塞轮询的方式获取套接字的状态,当其中任何一个套接字有数据可读或可写时,系统会通知应用程序进行相应的 I/O 操作。

信号驱动

I/O 信号驱动 I/O 模型允许应用程序注册一个信号处理函数,并在数据准备就绪时收到一个信号通知。然后应用程序可以在信号处理函数中执行 I/O 操作。

异步 I/O

异步 I/O 模型允许应用程序发起 I/O 操作后立即返回,并在数据传输完成时收到通知。这种模型通常需要操作系统或硬件设备的支持。

select()、poll() 和 epoll() 都是用于实现 I/O 多路复用的系统调用

select() 和 poll() 是阻塞的轮询文件描述符的方式来实现 I/O 多路复用的。

对于 select() 和 poll(),内核会在等待过程中阻塞,直到其中一个或多个监视的文件描述符上发生了 I/O 事件。

在没有事件发生时,应用程序仍然会被阻塞,而且需要周期性地轮询所有监视的文件描述符

epoll() 采用了事件驱动的方式,在有事件发生时立即通知应用程序,而不需要应用程序进行轮询。

对于 epoll(),内核会立即返回,并允许应用程序继续执行其他任务。当其中一个或多个文件描述符上发生了 I/O 事件时,内核会通知应用程序。

相关推荐
jason.zeng@15022074 分钟前
spring boot mqtt开发-原生 Paho 手动封装(最高灵活性,完全自定义)
java·spring boot·后端
sunnyday04269 分钟前
Filter、Interceptor、Spring AOP 的执行顺序详解
java·spring boot·后端·spring
想用offer打牌16 分钟前
一站式了解Spring AI Alibaba的Memory机制
java·人工智能·后端·spring·chatgpt·系统架构
打工的小王20 分钟前
Langchain4j(二)RAG知识库
java·后端·ai·语言模型
Remember_99335 分钟前
【数据结构】Java对象比较全解析:从equals到Comparable与Comparator,再到PriorityQueue应用
java·开发语言·数据结构·算法·leetcode·哈希算法
沛沛老爹1 小时前
从Web到AI:多模态Agent Skills生态系统实战(Java+Vue构建跨模态智能体)
java·前端·vue.js·人工智能·rag·企业转型
a努力。1 小时前
饿了么Java面试被问:一致性哈希的虚拟节点和数据迁移
java·chrome·后端·websocket·面试·职场和发展
把csdn当日记本的菜鸡1 小时前
Java设计模式简单入门
java·开发语言·设计模式
m0_748252381 小时前
Java 变量类型
java·数据结构·windows