请问swoole的进程模型是怎样的?
网友回复
swoole是一个多进程模型的框架,当启动一个进程swoole应用时,一共会创建2+n+m个进程,n为worker进程数,m为TaskWorker进程数,1个master进程和一个manager进程,关系如下图所示
其中三种进程之间的关系是:
Reactor线程:
负责维护客户端TCP连接、处理网络IO、处理协议、收发数据;
完全是异步非阻塞的模式;
全部为C代码,除Start/Shudown事件回调外,不执行任何PHP代码;
将TCP客户端发来的数据缓冲、拼接、拆分成完整的一个请求数据包;
Reactor以多线程的方式运行;
Worker进程
接受由Reactor线程投递的请求数据包,并执行PHP回调函数处理数据;
生成响应数据并发给Reactor线程,由Reactor线程发送给TCP客户端;
可以是异步非阻塞模式,也可以是同步阻塞模式;
Worker以多进程的方式运行;
TaskWorker进程task进程是swoole当中独立于worker进程的工作进程。用于处理一些耗时较长的逻辑,这些逻辑如果在工作当中处理时并不会影响worker进程处理来自于客户端的请求。由此大大提高了swoole扩展的并发能力。 在worker进程当中,通过调用 task() 方法,发送数据通知到task进程,task进程会在 onTask() 回调当中接收到这些数据并进行处理,处理完成之后调用 finish() 函数或者直接return返回消息给 worker进程,work...
点击查看剩余70%
为啥所有的照片分辨率提升工具都会修改照片上的图案细节?
js如何在浏览器中将webm视频的声音分离为单独音频?
微信小程序如何播放第三方域名url的mp4视频?
ai多模态大模型能实时识别视频中的手语为文字吗?
如何远程调试别人的chrome浏览器获取调试信息?
为啥js打开新网页window.open设置窗口宽高无效?
浏览器中js的navigator.mediaDevices.getDisplayMedia屏幕录像无法录制SpeechSynthesisUtterance产生的说话声音?
js中mediaRecorder如何录制window.speechSynthesis声音音频并下载?
python如何直接获取抖音短视频的音频文件url?
js在浏览器中如何使用MediaStream与MediaRecorder实现声音音频多轨道混流?