Swoole-基础常识
Swoole-初识
Swoole 使 PHP 开发人员可以编写高性能高并发的 TCP、UDP、Unix Socket、HTTP、 WebSocket 等服务,让 PHP 不再局限于 Web 领域。
Swoole 是一种高级PHP开发框架,框架不是为了提升网站的性能,是为了提升网站的开发效率、最少的性能损耗,换取最大的开发效率。
Swoole-结构图
Swoole-流程介绍
- Master
- 主进程处理核心事物的驱动
- Reactor [riˈæktər] ( 反应堆 )
- 负责维护客户端
TCP
连接、处理网络IO、处理协议、收发数据。 - 完全是异步非阻塞的模式。
- 全部为C代码,除
Start/Shudown
事件回调外,不执行任何 PHP 代码。 - 将
TCP
客户端发来的数据缓冲、拼接、拆分成完整的一个请求数据包。 Reactor
以多线程的方式运行。
- 负责维护客户端
- Manager
- Swoole中
worker/task
进程都是由Manager进程Fork(可以理解成:分支)
并管理的。 - 子进程结束运行时,Manager 进程负责回收此子进程,避免成为僵尸进程。并创建新的子进程。
- 服务器关闭时,Manager 进程将发送信号给所有子进程,通知子进程关闭服务。
- 服务器
reload
时,Manager 进程会逐个关闭 / 重启子进程。
- Swoole中
- Worker
- 接受由
Reactor
线程投递的请求数据包,并执行 PHP 回调函数处理数据。 - 生成响应数据并发给 Reactor 线程,由 Reactor 线程发送给 TCP 客户端。
- 可以是异步非阻塞模式,也可以是同步阻塞模式。
Worker
以多进程的方式运行。
- 接受由
- Task
- 接受由
Worker
进程通过 swoole_server->task/taskwait 方法投递的任务。 - 处理任务,并将结果数据返回(使用 swoole_server->finish)给 Worker 进程。
- 完全是同步阻塞模式。
TaskWorker
以多进程的方式运行。
- 接受由
Swoole-重点三者的关系:
- 三者是指:
Reactor、 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
之间可以紧密的结合起来,提供更高级的使用方式。
Swoole-举例说明运行原理
- 一个更通俗的比喻,假设 Server 就是一个工厂,那
Reactor
就是销售,接受客户订单。而Worker
就是技术经理,当销售接到订单后,Worker 去工作生产出客户要的东西。 而TaskWorker
可以理解为码农,可以帮助 Worker 干些杂事,让 Worker 专心工作。
底层会为
Worker
进程TaskWorker
进程分配一个唯一的ID。不同的
Worker
和TaskWorker
进程之间可以通过sendMessage
接口进行通信。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Rain!
评论