Unix网络IO模型

本文详细解析了Unix网络IO模型中的关键概念,如文件描述符、内核空间与用户空间,并对比介绍了阻塞IO、非阻塞IO、IO多路复用、信号驱动IO和异步IO的原理及工作流程。

Unix 网络IO模型

一、几个重要的概念

在Unix网络IO模型中,有几个比较重要的概念:用户空间、内核空间、用户态、内核态、文件描述符。

1.1 文件描述符

文件描述符在形式上是一个非负整数。实际上,它是一个索引值,指向内核为每一个进程所维护的该进程打开文件的记录表。

1.2 内核空间、用户空间、用户态、内核态

Linux系统中,为了进程之间互不影响,不让进程直接操作真实的物理内存,而是为每个进程分配虚拟内存地址(虚拟地址空间、寻址空间)。这个虚拟地址空间又被分为两部分:内核空间(四分之一)、用户空间(四分之三),内核空间是所有进程公用的。

所有的系统资源管理都是在内核空间完成。比如读写磁盘文件,分配回收内存,从网路接口读取数据等等。

内部输入—>内核空间---->用户空间---->用户进程

用户进程输入—> 用户空间----> 内核空间----> 外部

二、Unix网络IO模型

Unix提供了5种IO模型:阻塞IO、非阻塞IO、IO多路复用、信号驱动IO、异步IO。前四种都是同步IO、最后一个是异步IO。

2.1 阻塞IO

阻塞IO的工作流程:

  1. 应用进程发起系统调用;
  2. 阻塞等待内核准备好数据,直到数据在内核空间准备好,应用进程继续等待系统调用执行;
  3. 系统调用将数据从内核空间拷贝到用户空间后,应用进程开始处理其他任务;
    阻塞IO

2.2 非阻塞IO

非阻塞IO的工作流程:

  1. 应用进程发起系统调用,如果内核没有准备好数据,不阻塞立刻返回;
  2. 返回后应用进程可以做其他事情,但应用进程需要不断发起系统调用,询问数据是否准备好;
  3. 当某次系统调用得知数据准备好了,应用进程就会等待系统调用执行,直到数据从内核空间拷贝到用户空间,之后进程可以继续其他工作;
    非阻塞IO

2.3 IO多路复用

IO多路复用(又叫事件驱动IO),工作流程如下:

当应用进程自己不再发起系统调用,而是把系统调用交给select/poll/epoll 机制。

  1. 应用进程把一个或多个文件描述符交给select/poll/epoll;
  2. select/poll/epoll 通过文件描述符帮助应用进程检测数据报是否准备好,这个过程应用进程可以去干其它事情;
  3. 当select/poll/epoll监测到某个文件描述符有数据包准备好了,会通知应用进程;
  4. 然后应用进程等待系统调用执行,执行完成之后,应用进程再去干其他事情;

select、poll、epoll的区别:

selectpollepoll
操作方法遍历遍历回调
底层实现数组链表哈希表
IO效率每次调用都进行线性遍历,
事件复杂度为O(n)
每次调用都进行线性遍历,
事件复杂度为O(n)
事件通知方式,每当fd就绪,
系统注册的回调函数就会被通知,
将就绪fd放到rdlist里面。
事件复杂度O(1)
最大连接数1024(x86)或2048(x64)无上限无上限
fd拷贝每次调用select,
都需要把fd集合从用户态拷贝到内核态
每次调用poll,
都需要把fd集合从用户态拷贝到内核态
调用epoll_ctl时拷贝进内核并保存,
之后每次epoll_wait不拷贝。

IO多路复用

2.4 信号驱动IO

信息驱动IO到工作流程:

  1. 应用进程发出一个信号,后直接返回,等待内核准备好数据;
  2. 数据准备好后,应用进程收到一个信号;
  3. 应用进程等待数据从内核空间拷贝到用户空间,然后再干其他事儿;
    信号驱动IO

2.5 异步IO

异步IO的工作流程如下:

  1. 应用进程发起系统调用后,立刻返回去干其他事情;
  2. 内核等待数据准备好,并将数据从内核空间拷贝到用户空间,然后发信号通知应用进程数据已经拷贝完成;
  3. 应用进程收到信号后,继续其他任务;
    异步IO
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值