swoole 启动流程_Swoole 启动一个服务,开启了哪些进程和线程?

概述

Swoole 启动一个服务,开启了哪些进程和线程?

为了解决这个问题,咱们启动一个最简单的服务,一起看看究竟启动了哪些进程和线程?

然后结合官网运行流程图,对每个进程和线程进行归类。

服务启动后打印出当前 Swoole 版本 和 当前 CPU 核数。

打印 Swoole 版本,是让大家可以下载这个版本 去运行代码。

打印 CPU 核数,是因为这个参数下面会用到。

废话不多说,直接看代码吧。

代码

serv.php

class Server

{

private $serv;

public function __construct() {

$this->serv = new swoole_server("0.0.0.0", 9502);

$this->serv->set([

'worker_num' => 3,

'task_worker_num' => 3,

]);

$this->serv->on('Start', function ($serv) {

echo "SWOOLE:".SWOOLE_VERSION . " 服务已启动".PHP_EOL;

echo "SWOOLE_CPU_NUM:".swoole_cpu_num().PHP_EOL;

});

$this->serv->on('Receive', function ($serv, $fd, $from_id, $data) { });

$this->serv->on('Task', function ($serv, $task) { });

$this->serv->on('Finish', function ($serv, $task_id, $data) {});

$this->serv->start();

}

}

$server = new Server();

上面的代码简单说下,创建了一个 TCP 服务器,启动了 3 个 worker 进程, 3 个 task 进程,因为启用了 task 功能,所以必须注册 onTask、onFinish 2 个事件的回调函数。

咱们运行一下:

1197f61ffd5f245f31a79abf572078b3.png

使用 ps 查看下:

af97aa5bd4b49a870c9534ac6b6b6889.png

16390 的父进程是 16389。

16393、16394、16395、16396、16397、16398 的父进程是 16390。

有没有发现,16391、16392 去哪啦?是不是很奇怪。

再用 pstree 查看下:

a31f5f5bd3bc39f9e06e6ba67519dd9c.png

出来了吧,16391、16392 是线程 与 16390 进程一个层级。

现在我们了解了,启动的这个服务使用了 8 个进程、2 个线程。

我们一起看下官方 Swoole Server 的文档:

看下这张图:

793cee7e506cf4dbec775901d1c218f2.png

通过上面的图,我们可以得到结论:

16389 是 Master 进程。

16390 是 Manager 进程。

16391、16392 是 Reactor 线程。

16393、16394、16395、16396、16397、16398 包括 3 个 Worker 进程,3 个 Task 进程。

小结

一、为什么是 3 个 Worker 进程、3 个 Task 进程?

因为,在创建服务的时候我们进行了设置 worker_num = 3, task_worker_num = 3。

worker_num 如果不进行设置,默认为 SWOOLE_CPU_NUM,在上面咱们打印出来了,默认为 2,最大不超过,SWOOLE_CPU_NUM * 1000,具体详情,看官方文档。

worker_num 文档:

task_worker_num 文档:

二、为什么是 2 个 Reactor 线程?它是干什么的?

因为,Reactor 线程数,默认为 SWOOLE_CPU_NUM,也可以通过 reactor_num 参数进行设置。

reactor_num 文档:

它是真正处理 TCP 连接,收发数据的线程。

Reactor线程 文档:

三、Reactor、Worker、TaskWorker 的关系是什么样的?

一个通俗的比喻,假设Server就是一个工厂,那Reactor就是销售,接受客户订单。而Worker就是工人,当销售接到订单后,Worker去工作生产出客户要的东西。而TaskWorker可以理解为行政人员,可以帮助Worker干些杂事,让Worker专心工作。

官方已经解释的很详细了,看官方文档吧:

如果你想入门学习 Swoole 可以看下这个 《Swoole 文章汇总(10 篇)》。

一起学习

517d10ceb8a2cf693f817f15b65ae3bf.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
swoole_loader72_nzts_x64是一个针对PHP语言的扩展库,用于提供高性能的异步网络通信能力。Swoole是基于C语言开发的,可以让PHP程序实现多进程、多线程、协程等高并发处理的特性。 swoole_loader72_nzts_x64是针对PHP 7.2版本的64位操作系统的扩展库。目前,PHP7已经在性能上有了很大的提升,而swoole_loader72_nzts_x64进一步增强了PHP的并发处理能力。64位操作系统的支持能够更好地利用内存资源,提高程序运行效率。 通过使用swoole_loader72_nzts_x64,可以方便地开发一些高性能的网络应用,比如服务器、Web服务、游戏服务器等。swoole_loader72_nzts_x64提供了一系列的API函数,可以轻松实现TCP/UDP服务器,WebSocket服务器,定时器等功能。 相比于传统的PHP开发方式,swoole_loader72_nzts_x64的优势主要体现在以下几个方面: 1. 高并发:采用多进程/多线程/协程模型,可以同时处理成千上万的并发连接,大大提高了执行效率。 2. 高性能:通过底层C/C++编写,性能优越,能够在高负载的情况下依然保持稳定的性能表现。 3. 异步IO:支持异步非阻塞IO操作,减少了等待时间,提高了性能。 4. 内存管理:有效控制内存的使用,避免了内存泄漏和垃圾回收导致的性能损失。 5.易于使用:提供丰富的API函数和文档,开发者可以快速上手并使用。 总之,swoole_loader72_nzts_x64是一个非常有用的PHP扩展库,可以帮助开发者轻松实现高性能的网络应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值