PHP7中I/O模型内核剖析详解


Posted in PHP onApril 14, 2019

1.同步:我客户端(C端调用者)一个功能,该功能没有结束前,我死等结果。
2.异步:我(c端调用者)调用一个功能,不知道该功能结果,该功能有结果后通知我,即回调通知

3.阻塞:就是调用我(s端被调用者,函数),我(s端被调用者,函数)没有完全接受完数据或者没有得到结果之前,我不会返回。

4.非阻塞:就是调用我(s端被调用者,函数),我(s端被调用者,函数)立即返回,得出结果后通知调用者

五种I/O模型

(1) 阻塞I/O (Blocking I/O)

PHP7中I/O模型内核剖析详解

当用户进程进行系统调用时,内核就开始了I/O的第一个阶段,准备数据到缓冲区中,当数据都准备完成后,则将数据从内核缓冲区中拷贝到用户进程的内存中,这时用户进程才解除block的状态重新运行。

(2) 非阻塞I/O (Non-Blocking I/O)

PHP7中I/O模型内核剖析详解

用户进程只有在第二个阶段被阻塞了,而第一个阶段没有阻塞,但是在第一个阶段中,用户进程不需要盲等,不停的去轮询内核,看数据是否准备好了,因此该模型是比较消耗CPU的。

(3) I/O复用(I/O Multiplexing)

PHP7中I/O模型内核剖析详解

I/O执行的两个阶段都是用户进程都是阻塞的,但是两个阶段是独立的,在一次完整的I/O操作中,该用户进程是发起了两次系统调用。和阻塞I/O不同的是第一段可以等待多个描述符就绪

(4) 信号驱动的I/O (Signal Driven I/O)

PHP7中I/O模型内核剖析详解

只有在I/O执行的第二阶段阻塞了用户进程,而在第一阶段是没有阻塞的。该模型在I/O执行的第一阶段,当数据准备完成之后,会主动的通知用户进程数据已经准备完成,即对用户进程做一个回调。该通知分为两种,一为水平触发,即如果用户进程不响应则会一直发送通知,二为边缘触发,即只通知一次。

(5) 异步I/O (Asynchrnous I/O)

PHP7中I/O模型内核剖析详解

当用户进程发起系统调用后,立刻就可以开始去做其它的事情,然后直到I/O执行的两个阶段都完成之后,内核会给用户进程发送通知,告诉用户进程操作已经完成了。

I/O多路复用技术

select

(1).select()的机制中提供一fd_set的数据结构,每一个元素都能与一打开的文件句柄(不管是Socket句柄,还是其他 文件或命名管道或设备句柄)建立联系,建立联系的工作由程序员完成, 当调用select()时,由内核根据IO状态修改fd_set的内容,由此来通知执行了select()的进程哪一Socket或文件可读或可写。主要用于Socket通信当中。

(2).程序执行select后,如果没有数据输入,程序会一直等待(阻塞时),直到有数据为止,也就是程序中无需循环和sleep。

(3).每次调用select,都需要把fd_set集合从用户态拷贝到内核态,这个开销在fd_set很多时会很大

(4).同时每次调用select都需要在内核遍历传递进来的所有fd_set,这个开销在fd_set很多时也很大

(5).select支持的文件描述符数量太小了,默认是1024

poll

(1).poll的实现和select非常相似,只是描述fd_set集合的方式不同,poll使用pollfd链表结构而不是select的fd_set结构,其他的都差不多。

(2).监视描述符个数无上限;

epoll/kqueue

(1).监视描述符个数无上限;

(2).效率提升,不是轮询的方式,不会随着fd数目的增加效率下降。只有活跃可用的fd才会调用callback函数;即epoll/kqueue最大的优点就在于它只管你“活跃”的连接,而跟连接总数无关,因此在实际的网络环境中,epoll/kqueue的效率就会远远高于select和poll。

(3).内存拷贝,利用mmap()文件映射内存加速与内核空间的消息传递;

PHP 相关文章推荐
用PHP调用数据库的存贮过程
Oct 09 PHP
PHP中for循环语句的几种变型
Nov 26 PHP
PHP乱码问题,UTF-8乱码常见问题小结
Apr 09 PHP
PHP中数组的三种排序方法分享
May 07 PHP
php数组去重的函数代码
Feb 03 PHP
PHP array_multisort() 函数的深入解析
Jun 20 PHP
is_uploaded_file函数引发的不能上传文件问题
Oct 29 PHP
php实现快速排序的三种方法分享
Mar 12 PHP
浅谈PHP eval()函数定义和用法
Jun 21 PHP
PHP实现的redis主从数据库状态检测功能示例
Jul 20 PHP
Yii2压缩PHP中模板代码的输出问题
Aug 28 PHP
PHP获取数据库表中的数据插入新的表再原删除数据方法
Oct 12 PHP
浅析PHP7的多进程及实例源码
Apr 14 #PHP
什么是PHP7中的孤儿进程与僵尸进程
Apr 14 #PHP
php intval函数用法总结
Apr 14 #PHP
PHP中上传文件打印错误错误类型分析
Apr 14 #PHP
PHP扩展Swoole实现实时异步任务队列示例
Apr 13 #PHP
php+ajax实现商品对比功能示例
Apr 13 #PHP
PHP开发的文字水印,缩略图,图片水印实现类与用法示例
Apr 12 #PHP
You might like
PHP调用Twitter的RSS的实现代码
2010/03/10 PHP
php实现统计目录文件大小的函数
2015/12/25 PHP
在WordPress中安装使用视频播放器插件Hana Flv Player
2016/01/04 PHP
php图片添加水印例子
2016/07/20 PHP
Ajax和PHP正则表达式验证表单及验证码
2016/09/24 PHP
由JavaScript中call()方法引发的对面向对象继承机制call的思考
2011/09/12 Javascript
JSON无限折叠菜单编写实例
2013/12/16 Javascript
IE6下javasc#ipt:void(0) 无效的解决方法
2013/12/23 Javascript
jQuery:delegate中select()不起作用的解决方法(实例讲解)
2014/01/26 Javascript
jquery获取radio值(单选组radio)
2014/10/16 Javascript
浅谈jQuery事件绑定原理
2015/01/02 Javascript
jQuery实现鼠标跟随提示层效果代码(可显示文本,Div,Table,Html等)
2016/04/18 Javascript
JS获取年月日时分秒的方法分析
2016/11/28 Javascript
原生js实现中奖信息无间隙滚动效果
2017/01/18 Javascript
JS与jQuery实现子窗口获取父窗口元素值的方法
2017/04/17 jQuery
基于vue中css预加载使用sass的配置方式详解
2018/03/13 Javascript
Vue实现Layui的集成方法步骤
2020/04/10 Javascript
JavaScript实现拖拽和缩放效果
2020/08/24 Javascript
vue实现树状表格效果
2020/12/29 Vue.js
[01:56]2014DOTA2西雅图邀请赛 MVP外卡赛老队长精辟点评
2014/07/09 DOTA
python实现查询IP地址所在地
2015/03/29 Python
python实现定时自动备份文件到其他主机的实例代码
2018/02/23 Python
Python3实现的简单验证码识别功能示例
2018/05/02 Python
Python实现简单层次聚类算法以及可视化
2019/03/18 Python
用Python爬取QQ音乐评论并制成词云图的实例
2019/08/24 Python
python实现微信小程序用户登录、模板推送
2019/08/28 Python
Python破解BiliBili滑块验证码的思路详解(完美避开人机识别)
2020/02/17 Python
python3 使用openpyxl将mysql数据写入xlsx的操作
2020/05/15 Python
Selenium python时间控件输入问题解决方案
2020/07/22 Python
高职助产应届生自荐信
2013/09/24 职场文书
国庆促销活动总结
2014/08/29 职场文书
会议邀请函
2015/01/30 职场文书
2015社区精神文明建设工作总结
2015/04/21 职场文书
2015年维修工作总结
2015/04/25 职场文书
新闻通讯稿范文
2015/07/22 职场文书
quickjs 封装 JavaScript 沙箱详情
2021/11/02 Javascript