最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 14:42:56
文档

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

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'
推荐度:
导读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'

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 进程

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

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'
推荐度:
标签: php 中使用 task
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top