PHP7内核中IO模型是如何剖析的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1143个文字,预计阅读时间需要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操作中,该用户进程是发起了两次系统调用。
本文共计1143个文字,预计阅读时间需要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操作中,该用户进程是发起了两次系统调用。

