首页 技术 正文
技术 2022年11月11日
0 收藏 504 点赞 3,955 浏览 818 个字

Stevens 在文章中的一种IO Model:

****blocking IO    #阻塞 IO   (系统调用不返回结果并让当前线程一直阻塞,只有当该系统调用获得结果或者超时出错才返回)

****nonblocking IO #非阻塞IO (用户进程其实是需要不断的主动询问kernel数据准备好了没有)

select/epoll (事件驱动)

优点:能够在等待任务完成的时间里做其它的任务即多个任务同时执行

缺点:1 循环调用recv()  幅度的占用CPU 这也是我们在代码中留一句time.sleep(2) 的原因,否则在低配

主机下极易出现卡机状态   2  任务完成的响应延迟增大了,因为每次都是周期循环这会导致数据吞吐量的降

****IO multiplexing  #多路复用IO (进程调用select, 整个进程会被block,同时kernel会‘监视’所有select

负责的socket,当任何一个socket中的数据准备好了,select 就会返回,这个时候用户进程自动将数据

从kernel拷贝到用户进程)

结论: select的优势在于可以处理多个索拉,不适用于单个连接

优点:占用资源少,不消耗太多cpu ,同时能够为多客户端提供服务,

缺点:该模型将事件探测和事件响应夹杂在一起,一旦事件响应的执行体庞大,则对整个模型是灾难性的。

****signal driven IO # 信号驱动 IO

****asynchronous IO   #异步IO (用户开启进程,一方面立刻开始做其它的事,另一方面,从kernel的

角度当它受到io 后会立刻返回,不会对进程产生任何block,等待数据准备完成将数据拷贝到用户内存

结束后kernel会给用户进程发送一个signal,告诉它完成

对于network IO 会经历两个阶段:

    1  等待数据准备 (waiting)

      2  拷贝到进程(copy)

区别: blocking vs non-blocking  (前者会一起调用block住对应 的进程直到操作完成

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,495
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,133
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,297