旗下导航:搜·么
当前位置:网站首页 > PHP教程 > 正文

Swoole在PHP-fpm/apache中运用task功用【php教程】

作者:搜搜PHP网发布时间:2019-11-26分类:PHP教程浏览:88


导读:●新建RedisServer.php●代码以下<?phpuseSwoole\Redis\Server;$server=newServer("12...

● 新建 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 历程

相干引荐:【PHP教程】

以上就是Swoole在PHP-fpm/apache中运用task功用的细致内容,更多请关注ki4网别的相干文章!

标签:PHPSwoole