PHP7中IO模型内核剖析详解,能否详细阐述其工作原理与优化策略?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1074个文字,预计阅读时间需要5分钟。
1. 同步:我客户端(C端调用者)需要一个功能,该功能在没有结束前,我等待结果。
2.异步:我(C端调用者)调用一个功能,不知其结果,功能完成后通知我,立即调回通知。
3.阻塞:即阻塞调用。
1.同步:我客户端(C端调用者)一个功能,该功能没有结束前,我死等结果。
2.异步:我(c端调用者)调用一个功能,不知道该功能结果,该功能有结果后通知我,即回调通知
3.阻塞:就是调用我(s端被调用者,函数),我(s端被调用者,函数)没有完全接受完数据或者没有得到结果之前,我不会返回。
4.非阻塞:就是调用我(s端被调用者,函数),我(s端被调用者,函数)立即返回,得出结果后通知调用者
五种I/O模型
(1) 阻塞I/O (Blocking I/O)
当用户进程进行系统调用时,内核就开始了I/O的第一个阶段,准备数据到缓冲区中,当数据都准备完成后,则将数据从内核缓冲区中拷贝到用户进程的内存中,这时用户进程才解除block的状态重新运行。
(2) 非阻塞I/O (Non-Blocking I/O)
用户进程只有在第二个阶段被阻塞了,而第一个阶段没有阻塞,但是在第一个阶段中,用户进程不需要盲等,不停的去轮询内核,看数据是否准备好了,因此该模型是比较消耗CPU的。
(3) I/O复用(I/O Multiplexing)
I/O执行的两个阶段都是用户进程都是阻塞的,但是两个阶段是独立的,在一次完整的I/O操作中,该用户进程是发起了两次系统调用。
本文共计1074个文字,预计阅读时间需要5分钟。
1. 同步:我客户端(C端调用者)需要一个功能,该功能在没有结束前,我等待结果。
2.异步:我(C端调用者)调用一个功能,不知其结果,功能完成后通知我,立即调回通知。
3.阻塞:即阻塞调用。
1.同步:我客户端(C端调用者)一个功能,该功能没有结束前,我死等结果。
2.异步:我(c端调用者)调用一个功能,不知道该功能结果,该功能有结果后通知我,即回调通知
3.阻塞:就是调用我(s端被调用者,函数),我(s端被调用者,函数)没有完全接受完数据或者没有得到结果之前,我不会返回。
4.非阻塞:就是调用我(s端被调用者,函数),我(s端被调用者,函数)立即返回,得出结果后通知调用者
五种I/O模型
(1) 阻塞I/O (Blocking I/O)
当用户进程进行系统调用时,内核就开始了I/O的第一个阶段,准备数据到缓冲区中,当数据都准备完成后,则将数据从内核缓冲区中拷贝到用户进程的内存中,这时用户进程才解除block的状态重新运行。
(2) 非阻塞I/O (Non-Blocking I/O)
用户进程只有在第二个阶段被阻塞了,而第一个阶段没有阻塞,但是在第一个阶段中,用户进程不需要盲等,不停的去轮询内核,看数据是否准备好了,因此该模型是比较消耗CPU的。
(3) I/O复用(I/O Multiplexing)
I/O执行的两个阶段都是用户进程都是阻塞的,但是两个阶段是独立的,在一次完整的I/O操作中,该用户进程是发起了两次系统调用。

