
● 新建 redisserver.php
● 代码如下
立即学习“PHP免费学习笔记(深入)”;
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免费学习笔记(深入)”;
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 控制启动的进程数量
用 php + mysql 驱动的在线商城系统,我们的目标为中国的中小企业及个人提供最简洁,最安全,最高效的在线商城解决方案,使用了自建的会员积分折扣功能,不同的会员组有不同的折扣,让您的商店吸引更多的后续客户。 系统自动加分处理功能,自动处理会员等级,免去人工处理的工作量,让您的商店运作起来更方便省事 采用了自建的直接模板技术,免去了模板解析时间,提高了代码利用效率 独立开发的购物车系统,使用最
● 这些进程是由 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教程】










