Swoole 启动一个服务,开启了哪些进程和线程?
概述
Swoole 启动一个服务,开启了哪些进程和线程?
为了解决这个问题,咱们启动一个最简单的服务,一起看看究竟启动了哪些进程和线程?
然后结合官网运行流程图,对每个进程和线程进行归类。
服务启动后打印出当前 Swoole 版本 和 当前 CPU 核数。
打印 Swoole 版本,是让大家可以下载这个版本 去运行代码。
打印 CPU 核数,是因为这个参数下面会用到。
废话不多说,直接看代码吧。
代码
serv.php
<?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 个事件的回调函数。
咱们运行一下:

使用 ps 查看下:

16390 的父进程是 16389。
16393、16394、16395、16396、16397、16398 的父进程是 16390。
有没有发现,16391、16392 去哪啦?是不是很奇怪。
再用 pstree 查看下:

出来了吧,16391、16392 是线程 与 16390 进程一个层级。
现在我们了解了,启动的这个服务使用了 8 个进程、2 个线程。
我们一起看下官方 Swoole Server 的文档:
https://wiki.swoole.com/wiki/page/p-server.html
看下这张图:

通过上面的图,我们可以得到结论:
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 文档:
https://wiki.swoole.com/wiki/page/275.html
task_worker_num 文档:
https://wiki.swoole.com/wiki/page/276.html
二、为什么是 2 个 Reactor 线程?它是干什么的?
因为,Reactor 线程数,默认为 SWOOLE_CPU_NUM,也可以通过 reactor_num 参数进行设置。
reactor_num 文档:
https://wiki.swoole.com/wiki/page/281.html
它是真正处理 TCP 连接,收发数据的线程。
Reactor线程 文档:
https://wiki.swoole.com/wiki/page/347.html
三、Reactor、Worker、TaskWorker 的关系是什么样的?
一个通俗的比喻,假设Server就是一个工厂,那Reactor就是销售,接受客户订单。而Worker就是工人,当销售接到订单后,Worker去工作生产出客户要的东西。而TaskWorker可以理解为行政人员,可以帮助Worker干些杂事,让Worker专心工作。
官方已经解释的很详细了,看官方文档吧:
https://wiki.swoole.com/wiki/page/163.html
如果你想学习 Swoole 可以看下这个 《Swoole 文章汇总(10 篇)》。
本文欢迎转发,转发请注明作者和出处,谢谢!
Swoole 启动一个服务,开启了哪些进程和线程?的更多相关文章
- Mysql 本地计算机无法启动 mysql 服务 错误 1067:进程意外终
		1.重装后启动mysql服务,提示 本地计算机无法启动 mysql 服务 错误 1067:进程意外终止. 2.查看mysql根目录下有一 计算机名.err 打开一看全是英文的错误提示: 3.根据其中的 ... 
- Windows 无法启动MongoDB服务 错误1067:进程意外终止
		1:Windows 无法启动MongoDB服务 错误1067:进程意外终止 2:解决方法: 进入MongoDB安装目录\data\将此文件夹下的mongod.lock删除(网友提供解决方案,实验之后貌 ... 
- 无法启动mysql服务 错误1067:进程意外中止
		这个错误在前些周遇到过,没有解决,直接粗暴的卸载重装了,自己用的是wampserver集成环境,重装的后果是mysql里面的一些已有的数据库就没有了,有点小悲剧,不过幸好都是一些测试用的数据库,后面直 ... 
- Oracle服务无法启动,报:Windows无法启动OracleOraDb10g_home1TNSListener服务,错误 1067:进程意外终止。
		运行配置和移植工具中的Net Configuration Assistant,进行监听程序配置.删除配置,然后重新配置. 切记 一定是先删除配置,再重新配置,而不是新建配置. 或者 打开Net Man ... 
- Linux启动一个服务后,服务的某个文件所在的目录下出现类似:systemd-private.xxxxxx的目录
		Linux的目录下面形如: [root@:vg_adn_tidbCkhsTest:172.31.17.203 /var/lib/mysql]#ll /tmp total drwxr root root ... 
- php开启新的进程或者线程
		开启线程: $php_cli_path = '/usr/bin/php';$dir_path = dirname(__FILE__)."/".'CheckTaskState.she ... 
- 无法启动MYSQL服务”1067 进程意外终止”解决的方法
		自己一開始依照百度经验里的方法——<MySQL下载安装.配置与使用(win7x64)>去安装和配置,可是到后面步骤总是出现1067代号的错误. 慢慢折腾去解决. 这里汇总各种导致mysql ... 
- 无法启动MYSQL服务”1067 进程意外终止”解决的方法——汇总及终极方法
		自己一開始依照百度经验里的方法--<MySQL下载安装.配置与使用(win7x64)>去安装和配置,可是到后面步骤总是出现1067代号的错误. 慢慢折腾去解决. 这里汇总各种导致mysql ... 
- 在本地计算机无法启动MYSQL服务错误1067进程意外终止
		在本地计算机无法启动MYSQL服务错误1067进程意外终止 这种情况一般是my.ini文件配置出错了, 你可以删除系统目录下的my.ini文件, 把下面的内容重新写入my.ini文件试试, 要适当地改 ... 
随机推荐
- 这道面试必问的JVM面试题70%的Java程序员会做错
			前言 聊聊JVM,一个熟悉又陌生的名词,从认识Java的第一天起,我们就会听到这个名字,在参加工作的前一两年,面试的时候还会经常被问到JDK,JRE,JVM这三者的区别. JVM可以说和我们是老朋友了 ... 
- 1.1 Spring 概述
			1.1 Spring 概述 1.1.1 Spring 的简史 第一阶段:xml配置 Spring 1.x时代使用xml配置Bean 第二阶段:注解配置 Spring2.x Spring 提供了声明B ... 
- 获取本地计算机名称和Ip地址
			using System.Net; Dns.GetHostName();//获取本地计算机主机名 IPAddress[] IP = Dns.GetHostAddresses(Dns.GetHostNa ... 
- 《MySQL数据库》常用语法(一)
			MySQL从创建数据库到对表的增删改操作汇总. 1. 数据库操作: -- 查看所有的数据库 SHOW DATABASES ; -- 创建一个数据库,XXX表示数据库名称 CREATE DATABASE ... 
- Python面向对象-枚举类型enum
			枚举类型:在实际问题中,有些变量的值被限定在一个有限的范围内.例如:一个星期有且只有7天,一年有且只有十二个月,一个班每周有6门课程等等.如果把这些量说明为整型.字符串或者其他类型显然是不合适.编程界 ... 
- 网易极客战记官方攻略-地牢-Kithgard 图书管理员
			关卡连接: https://codecombat.163.com/play/level/kithgard-librarian 向友好的图书馆管理员求助! 简介 大多数关卡都有提示,在你卡关时挺有用. ... 
- JS---offset系列和scroll系列
			元素的样式属性是无法直接通过:对象.style.属性来获取(样式在style属性中设置) offset系列: offsetLeft:距离左边位置的值 offsetTop:距离上面位置的值 offs ... 
- Odoo系统有哪些不同版本?
			来源:www.odooyun.com 1. Odoo10.0 vs Odoo11.0 vs 8.0 截至2017年底,最新的Odoo发布版为Odoo 11.0,但功能上有一定精简(去除财务模块,去除工 ... 
- java之枚举和注解
			JDK1.5新增的enum关键字用于定义枚举类. 枚举类和普通类的区别: 使用enum定义的枚举类默认继承了java.lang.Enum类: 枚举类的构造器只能使用private修饰符: 枚举类的所有 ... 
- 解决:install service error:  InstallAsEventCreate() failed: xxx registry key already exists
			目录 一.事故现场 二.分析 三.解决方案 一.事故现场 在windows系统下安装服务,cmd窗口执行如下命令: "E:\work\_base\PsUm\PsUser\LdapWebSer ... 
