当前位置:首页 > PHP > 正文内容

swoole中的worker_num和task_worker_num

高老师7年前 (2019-05-05)PHP3585

(1)swoole启动的主进程是master进程负责全局管理,然后master进程会再fork一个manager进程。

(2)manager进程开始统一管理进程创建回收管理。

(3)manager进程根据设置的worker_num和task_worker_num来创建work进程和task进程

因此启动swoole我们能看到的进程数是:2+worker_num+task_worker_num,2中包含manager进程master进程

worker_num是用来处理请求逻辑的进程数,task_num是异步任务投递进程,专门处理异步任务的执行

例如下面的代码:

<?php
//构建Server对象
$server = new swoole_server("127.0.0.1", 9503);

//设置worker进程4个
$server->set([
    'worker_num' => 2,
    'task_worker_num' => 2,
    'daemonize' => false,
]);

//设置客户端连接回调
$server->on('connect', function ($server, $fd) {
});

$server->on('receive', function ($server, $fd, $reactor_id, $data) {
});

//设置客户端关闭回调
$server->on('close', function ($server, $fd) {
});

//设置Task回调
$server->on('Task', function ($serv) {
});

//启动服务器
$server->start();

查看进程:

gao       3429  0.0  0.2 238888 21460 tty1     Sl   11:26   0:00 php /mnt/d/wwwroot/todo/index.php
gao       3430  0.0  0.0  92684  3204 tty1     S    11:26   0:00 php /mnt/d/wwwroot/todo/index.php
gao       3433  0.0  0.0  88260  3364 tty1     S    11:26   0:00 php /mnt/d/wwwroot/todo/index.php
gao       3434  0.0  0.0  88260  3384 tty1     S    11:26   0:00 php /mnt/d/wwwroot/todo/index.php
gao       3435  0.0  0.0  88676  3524 tty1     S    11:26   0:00 php /mnt/d/wwwroot/todo/index.php
gao       3436  0.0  0.0  88676  3552 tty1     S    11:26   0:00 php /mnt/d/wwwroot/todo/index.php

还可以通过swoole提供的$server->manager_pid和$server->master_pid排除测试

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/89.html

分享给朋友:

“swoole中的worker_num和task_worker_num” 的相关文章

PHP数组重新排序

PHP数组重新排序

通常我们使用unset()删除数组的元素,数据的顺序并没有重置,使用array_merge()方法即可解决<?php $shoplist= array('a','b','c','d','e','...

php将html转为pdf,php将html页面导出pdf

php将html转为pdf,php将html页面导出pdf

首先下载wkhtmltox-0.12.4_linux-generic-amd64.tar.xz   (不要下载RPM包,依赖太多,需要x-server支持),并解压,执行测试运行正常tar wkhtmltox-0.12.4_linux-generic-amd64.tar.xzcd...

PHP高并发下数据库值更新的问题

PHP高并发下数据库值更新的问题

(1).创建数据库test ,创建表shop(字段id,total),商品id是1,商品总数10    (2).PHP模拟购买,商品数量大于0才能购买<?php //连接数据库 $con=mysqli_connect("192.168.2.18...

php异步执行,php后台运行,如何在windows下让php后台运行

php异步执行,php后台运行,如何在windows下让php后台运行

如果想在windows中执行php,并且让php脚本在后台运行,可以用下面的cmd命令start /b php  D:\wwwroot\default\demo1\run.php例如上面的命令意思后台运行run.php,如果想用php编写异步代码: ...

php上传大文件,php大文件上传

php上传大文件,php大文件上传

(1).前端文件:<form action="upload.php" method="post" enctype="multipart/form-data">    &...

Thinkphp Call Stack,PHP调用栈Call Stack的获取

Thinkphp Call Stack,PHP调用栈Call Stack的获取

ThinkPHP中有一个debug调试功能,能输出报错文件的信息,并能看到这个函数被哪些函数调用,从框架的启动开始记录,特别方便调试。于是研究了下它的底层给予了实现。<?php //--框架核心--Start //框架内置错误处理 function errDealWith($er...