温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Swoole在PHP-fpm/apache中如何使用task功能

发布时间:2020-07-09 14:17:58 来源:亿速云 阅读:202 作者:Leah 栏目:编程语言

Swoole在PHP-fpm/apache中如何使用task功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

● 新建 RedisServer.php

● 代码如下

<?php
use Swoole\Redis\Server;
$server = new Server("127.0.0.1", 9501, SWOOLE_PROCESS );
$server->set(array(
    'task_worker_num' => 32,
    'worker_num' => 1,
    'task_enable_coroutine' => true,
    'heartbeat_check_interval' => 5,
    'heartbeat_idle_time' => 10,
));
$server->setHandler('LPUSH', function ($fd, $data) use ($server) {
    $taskId = $server->task($data);
    if ($taskId === false) {
        $server->send($fd, Server::format(Server::ERROR));
    } else {
        $server->send($fd, Server::format(Server::INT, $taskId));
    }
});
$server->on('Finish', function($serv, $taskID, $data) {
    $stats = $serv->stats();
    if ($stats['tasking_num'] > 10) { //tasking_num 当前正在排队的任务数
        echo "剩余任务信息:" . json_encode($serv->stats()) . "\n";
    }
});
$server->on('Task', function ($serv, $data) {
    go(function () {
        usleep(50000);
    });
    var_dump($data);
});
$server->start();

task 里面 usleep (50000); 模拟任务执行时间

● 新建 Queue.php

● 代码如下

<?php
$redis = new Redis;
$redis->connect('127.0.0.1', 9501);
$x=1; 
while($x <= 1000) {
  $redis->lpush("myqueue", json_encode(array("hello".$x, "swoole")));
  $x++;
}

模拟 1000 的任务投递

经测试,1 秒处理完毕

可以根据 Task 任务执行的速度调节 task_worker_num 控制启动的进程数量


● 这些进程是由 swoole 底层负责管理的,在发生致命错误或进程退出后底层会重新创建新的任务进程

task_worker_num


● 最大值不得超过 SWOOLE_CPU_NUM * 1000

● 单个 task 的处理耗时,如 100ms,那一个进程 1 秒就可以处理 1/0.1=10 个 task

● task 投递的速度,如每秒产生 2000 个 task

● 2000/10=200,需要设置 task_worker_num => 200,启用 200 个 task 进程

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI