百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>网页制作> Swoole在PHP-fpm/apache中运用task功能
分享文章到:

Swoole在PHP-fpm/apache中运用task功能

发布时间:09/01 来源:未知 浏览: 关键词:

1.jpg

● 创建 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功效的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板