1.jpg

● 新建 RedisServer.php

● 代码如下

<?phpuse 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教程】

更多相关文章

  1. php实现共享内存进程通信函数之shm
  2. 多进程命名管通通信【无血缘关系进程】PHP 版本
  3. PHP 进程池与轮询调度算法实现多任务
  4. PHP 多进程和多线程的优缺点
  5. 解决CentOS7中php-fpm进程数过多导致服务器内存资源消耗较大的问
  6. HBase 底层原理详解(深度好文,建议收藏)
  7. 揭秘 Node.js 底层架构
  8. Linux进程管理
  9. 多线程学习(一) 线程与进程的理解

随机推荐

  1. 520|解锁Python表白新姿势
  2. Android(安卓)Studio真机测试时生成的程
  3. Python办公自动化|批量处理文件,一学就会
  4. 想做疫情分析却没有数据?看这篇就够了
  5. Python办公自动化|光速对比并提取两份Word
  6. Selenium自动化|爬取公众号全部文章,就是这
  7. Python办公自动化|自动更新表格,告别繁琐
  8. 收藏| Scrapy框架各组件详细设置
  9. 迭代学习 重视复盘——我的PMP备考之路(下
  10. 备战520|Python花式表白的几种姿势