PHP可通过pcntl扩展在CLI模式下实现多进程,利用pcntl_fork()创建子进程并独立运行,适用于Unix/Linux系统;多线程曾通过pthreads扩展实现,但仅支持PHP 7.2以下版本且需ZTS编译,现已废弃;现代推荐使用parallel扩展,支持闭包并行、异步任务与通道通信,更适合当前PHP生态;多进程适用于守护进程与CLI任务分发,多线程适合共享状态的高并发计算但需注意线程安全;Web环境通常由FPM管理进程,不推荐直接使用多进程或多线程,应根据实际场景选择pcntl、parallel或协程方案。

PHP本身并不像C或Java那样原生支持多线程或多进程编程,但通过一些扩展和技巧,可以在特定环境下实现类似功能。特别是在处理高并发任务、耗时操作分离或提升执行效率时,掌握PHP的多进程与多线程机制非常有价值。
多进程实现方法
在Unix/Linux系统下,PHP可以通过pcntl扩展来创建子进程,实现并行处理任务。
使用pcntl_fork()创建子进程:
- 调用pcntl_fork()会复制当前进程,返回值决定父子进程的执行路径。
- 返回值为-1表示失败;0表示子进程;大于0表示父进程,返回的是子进程PID。
- 每个进程独立运行,内存不共享,需通过信号、管道或文件等方式通信。
示例代码片段:
立即学习“PHP免费学习笔记(深入)”;
$pid = pcntl_fork();if ($pid == -1) {
die("无法创建子进程");
} elseif ($pid == 0) {
// 子进程逻辑
echo "这是子进程\n";
exit(0);
} else {
// 父进程等待子进程结束
pcntl_wait($status);
echo "子进程已结束\n";
}
注意:pcntl仅在CLI模式下可用,不适用于Web服务器环境(如Apache模块),且Windows不支持。
多线程实现方法
PHP默认不支持多线程,但可通过pthreads扩展实现多线程编程,不过该扩展仅适用于PHP 7.2以下版本且必须使用ZTS(Zend Thread Safety)编译的PHP。
pthreads基本用法:
- 定义一个类继承Threaded或Worker/Thread。
- 重写run()方法作为线程入口。
- 启动线程后,多个线程可共享对象数据(需注意同步问题)。
简单示例:
class MyThread extends Thread {public function run() {
echo "线程执行中\n";
}
}
$thread = new MyThread();
$thread->start();
$thread->join();
由于pthreads已被废弃(从PHP 7.2+不再维护),推荐使用parallel扩展作为替代方案。
现代替代方案:parallel扩展
parallel是PHP较新的并行编程扩展,支持多进程式并发,语法更现代,兼容性更好。
- 可在支持ZTS的PHP环境中运行。
- 提供parallel\run()快速执行闭包任务。
- 支持异步任务、通道通信等高级特性。
示例:
$result = parallel\run(function() {return "任务完成";
});
echo $result;
该扩展更适合当前PHP生态,尤其适合CLI下的并行任务处理。
适用场景与注意事项
多进程适合长时间运行的守护进程、任务分发、CLI脚本优化等场景。多线程则适合需要共享状态的高并发计算任务,但复杂度更高。
- Web环境下多进程受限,通常由SAPI(如FPM)管理进程模型。
- 线程安全问题是关键,避免资源竞争。
- 调试困难,日志记录要清晰区分进程/线程ID。
- 选择合适的通信机制:文件、数据库、Redis、消息队列等。
基本上就这些。根据实际环境选择pcntl、parallel或协程方案更现实。多进程相对成熟稳定,多线程需谨慎使用。











