现在的 Web 开发和过去最大的区别是什么?一句话:没人再愿意等服务器响应了。
七八年前,甚至更早的时候,模块加载、组件打包、脚本解释、数据库查询——这些步骤慢一点,对业务和用户也不会造成太大影响。
现在不一样了。Web 开发的核心已经变成了最大化服务器响应速度。这种转变来自网速的提升和单页应用(SPA)的普及。对后端来说,就是要能处理海量的快速请求,还得把负载分配好。
经典的双池架构(请求 worker + 任务 worker)不是凭空出现的。
一个请求一个进程的模型,根本扛不住大批量的轻量请求。该上并发了——一个进程同时处理多个请求。
并发处理带来了新要求:服务器代码要尽可能贴近业务逻辑。以前不是这样的。以前可以用 CGI 或 FPM 把 Web 服务器和脚本文件分得清清楚楚,很优雅。现在这招不好使了。
所以现在的方案要么就是把组件集成得尽量紧密,要么干脆把 Web 服务器当内部模块嵌进去。NGINX Unit 就是这么干的——它把 JavaScript、Python、Go 这些语言直接嵌到 worker 模块里。PHP 也有模块,但一直以来,PHP 在这种直接集成里没捞到什么好处,因为还是一个 worker 只能处理一个请求。
这个集成分三层:
nxt_unit_run()
nxt_unit_response_write_nb()
NginxUnit\Request
NginxUnit\Response
NginxUnit\HttpServer::onRequest()
HttpServer::onRequest()
HTTP 请求 → NGINX Unit → nxt_php_request_handler() ↓ 创建协程 (zend_async_coroutine_create) ↓ nxt_php_request_coroutine_entry() ↓ 创建 Request/Response 对象 ↓ 调用 entrypoint.php 中的回调函数 ↓ response->write() → nxt_unit_response_write_nb() ↓ response->end() → nxt_unit_request_done()
调用 $response->write($data) 时:
$response->write($data)
drain_queue
shm_ack_handler
{ "applications": { "my-php-async-app": { "type": "php", "async": true, // 启用 TrueAsync 模式 "processes": 2, // 工作器数量 "entrypoint": "/path/to/entrypoint.php", "working_directory": "/path/to/", "root": "/path/to/" } }, "listeners": { "127.0.0.1:8080": { "pass": "applications/my-php-async-app" } } }
重要:"async": true 会激活 TrueAsync SAPI,而不是标准的 PHP SAPI。
"async": true
curl -X PUT --data-binary @unit-config.json \ --unix-socket /tmp/unit/control.unit.sock \ http://localhost/config
基本结构:
<?php use NginxUnit\HttpServer; use NginxUnit\Request; use NginxUnit\Response; set_time_limit(0); // 注册请求处理器 HttpServer::onRequest(static function (Request $request, Response $response) { // 拿请求数据 $method = $request->getMethod(); $uri = $request->getUri(); // 设响应头 $response->setHeader('Content-Type', 'application/json'); $response->setStatus(200); // 发数据(非阻塞) $response->write(json_encode([ 'message' => 'Hello from TrueAsync!', 'method' => $method, 'uri' => $uri ])); // 结束响应 $response->end(); });
getMethod(): string
getUri(): string
getRequestContext(): ?mixed
getRequestContextParameters(): ?mixed
createResponse(): Response
setStatus(int $code): bool
setHeader(string $name, string $value): bool
write(string $data): bool
end(): bool
注意:
setStatus()
setHeader()
write()
end()
HttpServer::onRequest(function (Request $req, Response $resp) { // 1. 响应头还能改 $resp->setStatus(200); $resp->setHeader('Content-Type', 'text/plain'); // 2. 第一次 write() 把响应头发出去了 $resp->write('Hello '); // 3. 现在响应头改不了了 // $resp->setHeader() → 报错! // 4. 可以继续写数据 $resp->write('World!'); // 5. 结束请求(必须调!) $resp->end(); });
./build/sbin/unitd \ --no-daemon \ --log /tmp/unit/unit.log \ --state /tmp/unit \ --control unix:/tmp/unit/control.unit.sock \ --pid /tmp/unit/unit.pid \ --modules ./build/lib/unit/modules
重要:--modules 参数必须加,用来加载 PHP 模块。
--modules
tail -f /tmp/unit/unit.log
curl http://127.0.0.1:8080/
响应:
{ "message": "Hello from NginxUnit TrueAsync HttpServer!", "method": "GET", "uri": "/", "timestamp": "2025-10-04 15:30:00" }
wrk -t4 -c100 -d30s http://127.0.0.1:8080/
gdb ./build/sbin/unitd (gdb) set follow-fork-mode child (gdb) run --no-daemon --log /tmp/unit/unit.log ...
break nxt_php_request_handler break nxt_php_request_coroutine_entry break nxt_unit_response_write_nb
# 停止所有 NGINX Unit 进程 pkill -9 unitd # 检查控制套接字 ls -la /tmp/unit/control.unit.sock # 获取当前配置 curl --unix-socket /tmp/unit/control.unit.sock http://localhost/config
nxt_php_extension_init()
NginxUnit
entrypoint.php
nxt_php_request_callback
nxt_php_request_handler(req)
zend_async_coroutine_create(nxt_php_request_coroutine_entry)
req
nxt_unit_response_buf_alloc
zend_async_coroutine_activate()
nxt_php_request_coroutine_entry()
response->end()
response->write()
shm_ack_handler()
Request::getRequestContext()
NGINX Unit TrueAsync PHP 集成让 PHP 真正拥有了异步处理能力。通过协程机制,单个进程可以同时处理多个请求,这在过去是无法想象的。
对于 PHP 生态来说,这是一个重要的转折点。传统的 PHP-FPM 模式下,每个请求独占一个进程,在高并发场景下资源消耗巨大。现在有了 TrueAsync,PHP 可以像 Node.js、Go 那样高效处理并发请求,同时保持语言本身的简洁性。
虽然目前还有一些功能在开发中,比如完整的请求头支持、POST 数据解析、WebSocket 等,但现有的功能已经足够构建高性能的 API 服务。非阻塞 I/O、协程调度、事件循环——这些核心机制都已经就位。
对于需要处理高并发请求的 PHP 应用,特别是 API 服务、微服务架构,NGINX Unit TrueAsync 提供了一个值得认真考虑的选择。它不需要改变太多现有代码结构,却能带来性能上的显著提升。