三种角色分别的职责是:
TCP
连接、处理网络IO
、处理协议、收发数据C
代码,除Start
/Shudown
事件回调外,不执行任何PHP代码TCP
客户端发来的数据缓冲、拼接、拆分成完整的一个请求数据包Reactor
以多线程的方式运行Reactor
线程投递的请求数据包,并执行PHP
回调函数处理数据Reactor
线程,由Reactor
线程发送给TCP
客户端Worker
以多进程的方式运行Worker
进程通过swoole_server->task/taskwait
方法投递的任务swoole_server->finish
)给Worker
进程TaskWorker
以多进程的方式运行可以理解为Reactor
就是nginx
,Worker
就是php-fpm
。Reactor
线程异步并行地处理网络请求,然后再转发给Worker
进程中去处理。Reactor
和Worker
间通过UnixSocket
进行通信。
在php-fpm
的应用中,经常会将一个任务异步投递到Redis
等队列中,并在后台启动一些php
进程异步地处理这些任务。Swoole
提供的TaskWorker
是一套更完整的方案,将任务的投递、队列、php
任务处理进程管理合为一体。通过底层提供的API
可以非常简单地实现异步任务的处理。另外TaskWorker
还可以在任务执行完成后,再返回一个结果反馈到Worker
。
Swoole
的Reactor
、Worker
、TaskWorker
之间可以紧密的结合起来,提供更高级的使用方式。
一个更通俗的比喻,假设Server
就是一个工厂,那Reactor
就是销售,接受客户订单。而Worker
就是工人,当销售接到订单后,Worker
去工作生产出客户要的东西。而TaskWorker
可以理解为行政人员,可以帮助Worker
干些杂事,让Worker
专心工作。
底层会为
Worker
进程、TaskWorker
进程分配一个唯一的ID
不同的Worker
和TaskWorker
进程之间可以通过sendMessage
接口进行通信