UNIX网络5种I/O模型

本文深入探讨了阻塞I/O、非阻塞I/O、I/O复用、信号驱动I/O及异步I/O模型的工作原理,重点介绍了epoll作为高效I/O复用技术的优势,包括支持大量socket描述符、高效率处理、内存映射加速消息传递等特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 阻塞I/O 模型, 进程空间调用recvfrom时,系统调用直到数据包到达且被复制到应用进程的缓冲区中或者发生错误时才返回,在此期间一直会等待,进程在从调用recvfrom开始到它返回的整段时间内都是被阻塞的,因此被称为阻塞I/O模型。
  2. 非阻塞I/O模型: recvfrom从应用层到内核的时候,如果该缓冲区没有数据的话,就直接返回一个EWOULDBLOCK错误,一般都对非阻塞I/O模型进行轮询检查这个状态,看内核是不是有数据到来。
  3. I/O复用模型: Linux 提供select/poll,进程通过将一个或多个fd传递给select或poll系统调用,阻塞在select操作上,这样select/poll可以侦测多个fd是否处于就绪状态。select/poll是顺序扫描fd是否就绪,而且支持的fd数量有限。 其中select采用fd_set的数据结构,fd数量有限制,一般为1024,而poll采用链表的方式,破解了1024的限制,但是他们都是顺序扫描的,效率很低。 linux还提供了epoll系统调用,epoll使用基于事件驱动方式替代顺序扫描,当fd就绪时,立即回调函数rollback
  4. 信号驱动I/O模型: 首先开启套接口信号驱动I/O功能,并通过系统调用sigaction执行一个信号处理函数,该处理函数立即返回,进程继续工作非阻塞,当数据准备就绪时,就为进程生成一个SIGIO信号,通过信号回调通知应用程序调用recvfrom来读取数据。
  5. 异步I/O: 告知内核启动某个操作,并在内核在整个操作完成后(包括把数据从内核复制到用户自己的缓冲区)通知我们, 异步I/O和信号驱动I/O驱动模型的主要区别是: 信号驱动I/O由内核通知用户何时可以开始一个I/O操作; 异步I/O模型由内核通知我们I/O操作何时已经完成。

I/O多路复用技术适用场景如下:

  • 服务器需要同时处理多个处于监听状态或者多个连接状态的套接字
  • 服务器需要同时处理多种网络协议的套接字。

epoll的优点:

  1. 支持一个进程打开的socket描述符不受限制,仅受限于操作系统的最大文件句柄数。
  2. I/O效率不会随着FD数目的增加而线性下降。 但是epoll适用于有大量不活跃状态的连接。
  3. 使用mmap内存映射,避免不必要的内存复制,加速内核与用户空间的消息传递。
  4. epoll的api更加简单。 包括创建一个epoll描述符,添加监听事件,阻塞等待监听的事件发生,关闭epoll描述符等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值