异步任务处理可通过消息队列、系统调用或Swoole实现。首先将耗时操作剥离主流程,Web层入队后快速响应,Worker进程后台执行任务。推荐使用RabbitMQ、Redis或Kafka作为消息队列,结合supervisor守护进程;轻量级场景可用exec+&、cURL多线程或fastcgi_finish_request()实现简单异步;高性能需求可引入Swoole扩展,利用协程并发处理任务。选择方案需根据业务规模,小项目用fastcgi_finish_request或shell,中大型上消息队列,高并发选Swoole。

PHP本身是同步阻塞的,但可以通过多种方式实现异步任务处理。重点在于把耗时操作从主流程中剥离,让请求快速响应,后台慢慢执行任务。
最稳定可靠的异步方案是结合消息队列,比如RabbitMQ、Redis Queue或Kafka。
流程:Web请求触发后,把任务推入队列,由独立的Worker进程消费执行。
// 入队(web层)
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->lpush('task_queue', json_encode(['action' => 'send_email', 'to' => 'user@demo.com']));
// 出队(worker.php,命令行运行)
while (true) {
$task = $redis->brpop('task_queue', 30);
if ($task) {
// 执行发送邮件等逻辑
sendEmail($task[1]);
}
}
适合轻量级任务,比如记录日志、推送通知。
立即学习“PHP免费学习笔记(深入)”;
echo "页面已加载";
fastcgi_finish_request(); // 客户端已收到响应
// 后续代码异步执行
sleep(2); // 模拟耗时
file_put_contents('log.txt', '后台记录');
Swoole提供了事件驱动、协程支持,能让PHP像Node.js一样写异步代码。
use Swoole\Coroutine as Co;
Co\run(function () {
$client1 = new Co\Http\Client('httpbin.org', 80);
$client1->set(['timeout' => 10]);
$client1->get('/delay/2');
$client2 = new Co\Http\Client('httpbin.org', 80);
$client2->get('/delay/3');
// 并行执行,总耗时约3秒
});
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号