swoole的task默认为异步,调用$server->task($data)立即返回任务ID,不阻塞主进程,结果通过onFinish回调获取;若需同步等待结果,可使用$server->taskWait()或协程模式下的taskCo(),前者阻塞等待直至任务完成或超时,后者在协程中实现非阻塞等待,适合需要结果继续执行的场景。

Swoole 的 task 方法默认是异步的,但也可以配置为同步等待结果。
默认情况:异步 task
当你在 Swoole 服务器中调用 $server->task($data) 时,这个调用会立即返回一个任务 ID,不会阻塞当前进程。任务被投递到 task 进程池中,由 worker 进程或专门的 task 进程处理。
特点:
- 主 Worker 进程不等待执行结果
- 任务投递后立刻继续执行后续代码
- 结果通过 onFinish 回调获取
示例:
$taskId = $server->task("hello"); echo "任务已投递,ID: {$taskId}n"; // 立刻输出
同步 task:使用 taskwait
如果你需要等待任务执行结果,可以使用 $server->taskWait() 或 taskCo()(协程模式)。
这时程序会阻塞,直到任务完成并返回结果,最长可设置超时时间。
-
taskWait在主进程等待,适用于同步场景 - 返回结果或 false(超时/失败)
- 适合需要结果才能继续的逻辑
示例:
$result = $server->taskWait("hello", 5.0); // 最多等5秒 if ($result !== false) { echo "任务结果: {$result}"; }
协程环境下:taskCo 更优雅
在 Swoole 协程模式下,推荐使用 taskCo,它在语法上像同步,实际是非阻塞的协程调度。
- 写法简单,像同步调用
- 底层自动挂起协程,不占用线程
- 支持 await 风格编程
基本上就这些,Swoole 的 task 默认异步,按需可转同步等待。


