Swoole 快速起步:Task 任务机制的使用

Swoole的Task任务机制用于处理耗时进程,避免阻塞主进程。在WebSocket服务器示例中,通过Task异步处理耗时操作,显著减少了从开始流程到完成的时间,提高了服务器性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Task任务机制实际是 将耗时进程投递到异步调用事件Task中处理,从而不阻塞主进程

 Swoole 快速起步:创建 WebSocket 服务器(聊天室)为例,在 WebSocket 服务器监听到新消息相应时,需要一些耗时的操作之后才将数据 send 给客户端,如果不使用Task任务机制时:

// 监听 WebSocket 消息事件
$server->on('message', function ($server, $frame) {
    // 开始流程
	echo date("Y-m-d H:i:s") . ":get something\n";
    
    // 耗时的任务开始
	sleep(5);
	echo date("Y-m-d H:i:s") . ":handle something\n";
    // 耗时的任务结束

    foreach ($server->connections as $k => $v) {
        $server->push($v, "会员".$frame->fd.":".$frame->data);
    }
    // 流程完成
    echo date("Y-m-d H:i:s") . ":finish it\n";
});

结果如下:

可见,在开始流程(get something)到 流程完成(finish it)一共耗时 5 秒,原因就在于 那个耗时的任务 sleep(5) !

如果将耗时任务投放到 Task 中做处理:

// 配置
$server->set([
    "worker_num" => 2,
    "task_worker_num" => 2
]);

/* ... */

// 监听 WebSocket 消息事件
$server->on('message', function ($server, $frame) {
    // 开始流程
    echo date("Y-m-d H:i:s") . ":get something\n";

    // 耗时的任务开始
    $data = "task go!!!";
    $server->task($data);
    // 耗时的任务结束

    foreach ($server->connections as $k => $v) {
        $server->push($v, "会员" . $frame->fd . ":" . $frame->data);
    }
    // 流程完成
    echo date("Y-m-d H:i:s") . ":finish it\n";
});

$server->on("Task", function ($server, $taskId, $workerId, $data) {
    var_dump($data); // $data 来源 $server->task($data); 参数
    sleep(5);
    echo date("Y-m-d H:i:s") . ":handle something\n";
    return "task ok!!!";
});

$server->on("Finish", function ($server, $taskId, $data) {
    var_dump($data);  // $data 来源 onTask($data) return 结果
});

结果:

可见,在开始流程(get something) 到 流程完成(finish it)几乎不消耗时间!因为那耗时 5 秒的任务投放在 Task 中异步处理!

发现很多所谓的 高性能 都是将进程投递到其它进程 异步处理,然后实现监听处理结果!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值