Linux下的IO模型

先来了解一下同步,异步,阻塞,非阻塞的概念

同步:

所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。也就是必须一件一件事做,等前一件做完了才能做下一件事。

异步:

异步的概念和同步相对。当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者。

阻塞:

阻塞调用是指调用结果返回前,当前线程会被挂起(线程进入非可执行状态,在这个状态下,cpu不会给线程分配时间片,既线程暂停运行)。函数只有在得到结果之后才会返回。

有人也许会把阻塞调用和同步调用等同起来,实际上他是不同的。对于同步调用来说,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回,它还会抢占cpu去执行其他逻辑,也会主动检测io是否准备好。

非阻塞:

和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。

再简单点理解就是:

同步,就是我调用一个功能,该功能没有结束前,我死等结果。

异步,就是我调用一个功能,不需要知道该功能结果,该功能有结果后通知我(回调通知)

阻塞,就是调用我(函数),我(函数)没有接受完数据或者没有都得到结果之前,我不会返回。

非阻塞,就是调用我(函数),我(函数)立即返回,不管成功与否

同步IO和异步IO的区别就在于:数据拷贝的时候进程是否阻塞

阻塞IO和非阻塞IO的区别就在于:应用程序的调用是否立即返回

综上可知,同步和异步,阻塞和非阻塞,有些混用,其实它们完全不是一回事,而且它们修饰的对象也不同,阻塞和非阻塞说的是进程状态,同步异步说的进程逻辑。

五种IO模型:

阻塞I/O (blocking I/0)

非阻塞I/0 (nonblocking I/0)

I/0复用 (select、po11、epo1l)(I/0 multiplexing)

信号驱动I/0 (signal driven I/0 (SIGI0) )

异步I/0 (asynchronous I/O (the POSIX aio_ functions) )

其中前4种都是同步,最后一种才是异步。

阻塞I/O:

应用程序调用一个I0函数,导致应用程序阻塞,等待数据准备好。如果数据没有准备好,-直等待..数据准备好了,从内核拷贝到用户空间, I0函数返回成功指示。阻塞I/0模型图:在调用read() /recv()/recvfrom ()函数时,发生在内核中等待数据和复制数据的过程。

当调用recv()函数时,系统首先检查是否有准备好的数据。如果数据没有准备好,那么系统就处于等待状态。当数据准备好后,将数据从系统缓冲区复制到用户空间,然后该函数返回。在套接应用程序中,当调用recv()函数时,未必用户空间就己经存在数据,那么此时recv()函数就会处于等待状态。

非阻塞IO:

非阻塞I0通常进程会反复调用I0函数(多次系统调用,并马上返回) ;在数据拷贝的过程中,进程是阻塞的。我们把一个S0CKET接口设置为非阻塞就是告诉内核,当所请求的I/0操作无法完成.时,不要将进程睡眠,而是返回一个错误。这样我们的I/0操作函数将不断的测试数据是否已经准备好,如果没有准备好,继续测试,直到数据准备好为止。在这个不断测试的过程中,大量的占用CPU的时间。

IO复用:

主要是select和epoll;对一个I0端口,两次调用,两次返回,比阻塞I0并没有什么优越性;关键是能实现同时对多个I0端口进行监听; I/0复 用模型会用到select、poll、epoll函数,这几个函数也会使进程阻塞,但是和阻塞I/0所不同的,这两个函数可以同时阻塞多个I/0操作。而且可以同时对多个读操作,多个写操作的I/0函数进行检测,直到有数据可读或可写时,才真正调用I/0操作函数。

 

 

信号驱动IO:

首先我们允许套接口进行信号驱动I/0,并安装-一个信号处理函数,进程继续运行并不阻塞。当数据准备好时,进程会收到一个SIGI0信号,可以在信号处理函数中调用I/0操作函数处理数据。

 

异步IO:

当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者的输入输出操作。

 五种IO模型总结:

 

什么是IO多路复用?

IO多路复用是一种同步IO模型,实现一个线程可以监视多个文件句柄;

一旦某个文件句柄就绪,就能够通知应用程序进程相应的读写操作;

没有文件句柄就绪就会阻塞应用程序,交出cpu。

多路是指网络连接,复用指的的是同一个进程。

服务器端采用单线程通过select/poll/epoll等系统调用获取fd列表,遍历有事件的fd进行accept/recv/send,使其能支持更多的并发连接请求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值