【网络编程】Unix下IO模型及他们之间的区别

简介: Unix下5种IO模型他们之间的区别

 目录

一:Unix下5种IO模型

二:他们之间的区别


一:Unix下5种IO模型

    • 阻塞式IO
    • 非阻塞式IO
    • IO多路复用(select和poll)
    • 信号驱动式IO(SIGIO)
    • 异步IO

    对于一个套接字上的输入操作,两个阶段:

    1)等待数据从网络中到达,被复制到内核中的某个缓冲区;

    2)将数据从内核缓冲区复制到应用进程缓冲区;

      1. 阻塞式IO模型
        网络异常,图片无法展示
        |
        image.gif编辑

        进程调用recvfrom,其系统调用直到数据报到达且被拷贝到应用进程的缓冲区中或者发生错误才返回。最常见的错误是系统调用被信号中断。我们说进程在从调用recvfrom开始到它返回的整段时间内是被阻塞的。recvfrom成功返回后,应用进程开始处理数据。
      2. 非阻塞式IO
        进程把一个套接口设置成非阻塞是在通知内核:当所请求的I/O操作非得把本进程投入睡眠才能完成时,不要把本进程投入睡眠,而是返回一个错误。下图展示了非阻塞I/O模型。
        image.gif编辑
        前三次调用recvfrom时没有数据可返回,因此内核转而立即返回一个EWOULDBLOCK错误。第四次调用 recvfrom时已有数据报准备好,它被拷贝到应用进程缓冲区,recvfrom于是成功返回。我们接着处理数据。
        当一个应用进程像这样对一个非阻塞描述字循环调用recvfrom时,我们称之为轮询(polling)。应用进程持续轮询内核,以查看某个操作是否就绪。这么做往往耗费大量CPU时间,不过这种模型偶尔也会遇到,通常是在只专门提供某种功能的系统中才有。
      3. IO多路复用
        有了I/O复用(I/O multiplexing),我们就可以调用select或poll,阻塞在这两个系统调用中的某一个之上,而不是阻塞在真正的I/O系统调用上。下图展示了I/O复用模型。
        我们阻塞于select调用,等待数据报套接口变为可读。当select返回套接口可读这一条件时,我们调用recvfrom把所读数据报拷贝到应用进程缓冲区。

      与I/O复用密切相关的另一种I/O模型是在多线程中使用阻塞I/O。这种模型与I/O复用模型极为相似,代替使用select阻塞在多个文件描述字上的是,使用多个线程(每个文件描述字一个线程),这样每个线程都可以自由地调用诸如recvfrom之类的阻塞式I/O系统调用了。

      1. 信号驱动式IO(SIGIO)
        我们也可以用信号,让内核在描述字就绪时发送SIGIO信号通知我们。
        我们首先开启套接口的信号驱动I/O功能,并通过sigaction系统调用安装一个信号处理函数。该系统调用立即返回,我们的进程继续工作,也就是说它没有被阻塞。当数据报准备好读取时,内核就为该进程产生一个SIGIO信号。我们随后既可以在信号处理函数中调用recvfrom读取数据报,并通知主循环数据已准备好待处理,也可以立即通知主循环,让它读取数据报
        网络异常,图片无法展示
        |
        image.gif编辑

      2. 异步IO
        一般地说,这些函数的工作机制是:告知内核启动某个操作,并让内核在整个操作(包括将数据从内核拷贝到我们自己的缓冲区)完成后通知我们。
        这种模型与信号驱动模型的主要区别在于:信号驱动I/O是由内核通知我们何时启动一个I/O操作,而异步I/O模型是由内核通知我们I/O操作何时完成。

      网络异常,图片无法展示
      |
      image.gif 编辑

      二 :IO模型的比较

      网络异常,图片无法展示
      |
      image.gif 编辑


      相关文章
      |
      2月前
      |
      Java Linux API
      IO模型
      BIO、NIO、AIO是Java中处理网络I/O的三种模型。BIO为阻塞式,每个连接需单独线程,高并发下性能受限;NIO通过非阻塞与多路复用提升并发能力,少量线程可处理大量请求;AIO进一步实现异步非阻塞,数据复制时线程可释放,由回调机制处理后续操作。三者适用于不同场景,BIO易用但低效,NIO高效但复杂,AIO理论性能更优但目前在Linux上仍依赖多路复用实现。Java 21引入虚拟线程后,BIO也可兼具高性能与易编写特性。
      85 2
      |
      4月前
      |
      监控 应用服务中间件 Linux
      掌握并发模型:深度揭露网络IO复用并发模型的原理。
      总结,网络 I/O 复用并发模型通过实现非阻塞 I/O、引入 I/O 复用技术如 select、poll 和 epoll,以及采用 Reactor 模式等技巧,为多任务并发提供了有效的解决方案。这样的模型有效提高了系统资源利用率,以及保证了并发任务的高效执行。在现实中,这种模型在许多网络应用程序和分布式系统中都取得了很好的应用成果。
      132 35
      |
      Ubuntu 网络协议 Unix
      02理解网络IO:实现服务与客户端通信
      网络IO指客户端与服务端通过网络进行数据收发的过程,常见于微信、QQ等应用。本文详解如何用C语言实现一个支持多客户端连接的TCP服务端,涉及socket编程、线程处理及通信流程,并分析“一消息一线程”模式的优缺点。
      185 0
      |
      6月前
      |
      存储 网络协议 安全
      Java网络编程,多线程,IO流综合小项目一一ChatBoxes
      **项目介绍**:本项目实现了一个基于TCP协议的C/S架构控制台聊天室,支持局域网内多客户端同时聊天。用户需注册并登录,用户名唯一,密码格式为字母开头加纯数字。登录后可实时聊天,服务端负责验证用户信息并转发消息。 **项目亮点**: - **C/S架构**:客户端与服务端通过TCP连接通信。 - **多线程**:采用多线程处理多个客户端的并发请求,确保实时交互。 - **IO流**:使用BufferedReader和BufferedWriter进行数据传输,确保高效稳定的通信。 - **线程安全**:通过同步代码块和锁机制保证共享数据的安全性。
      247 23
      |
      6月前
      |
      机器学习/深度学习 API Python
      Python 高级编程与实战:深入理解网络编程与异步IO
      在前几篇文章中,我们探讨了 Python 的基础语法、面向对象编程、函数式编程、元编程、性能优化、调试技巧、数据科学、机器学习、Web 开发和 API 设计。本文将深入探讨 Python 在网络编程和异步IO中的应用,并通过实战项目帮助你掌握这些技术。
      |
      7月前
      |
      缓存 网络协议 Java
      JAVA网络IO之NIO/BIO
      本文介绍了Java网络编程的基础与历史演进,重点阐述了IO和Socket的概念。Java的IO分为设备和接口两部分,通过流、字节、字符等方式实现与外部的交互。
      229 0
      |
      11月前
      |
      网络协议 前端开发 Java
      网络协议与IO模型
      网络协议与IO模型
      381 4
      网络协议与IO模型
      |
      10月前
      |
      存储 关系型数据库 MySQL
      查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
      查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
      4643 2
      |
      10月前
      |
      网络协议 物联网 API
      Python网络编程:Twisted框架的异步IO处理与实战
      【10月更文挑战第26天】Python 是一门功能强大且易于学习的编程语言,Twisted 框架以其事件驱动和异步IO处理能力,在网络编程领域独树一帜。本文深入探讨 Twisted 的异步IO机制,并通过实战示例展示其强大功能。示例包括创建简单HTTP服务器,展示如何高效处理大量并发连接。
      165 1
      |
      11月前
      |
      开发者
      什么是面向网络的IO模型?
      【10月更文挑战第6天】什么是面向网络的IO模型?
      89 3

      热门文章

      最新文章