PHP长连接指在常驻内存环境中复用数据库或缓存连接,减少频繁创建开销。1. 传统FPM模式每次请求重建连接,效率低;2. 长连接通过持久化连接实现复用,常见于Swoole、Workerman等环境;3. MySQL可通过PDO或mysqli持久连接,Redis可在协程中复用连接;4. 结合协程与连接池可提升并发能力;5. 需注意连接失效重连、资源泄露及合理配置连接数。真正发挥长连接优势需运行在常驻内存服务中。
PHP长连接通常指的是在PHP应用中与后端服务(如数据库、缓存、消息队列等)保持长时间的连接,而不是每次请求都重新建立和关闭连接。这种机制可以减少频繁建立连接带来的开销,提升性能。
在传统的PHP运行模式中(如使用Apache的mod_php),每个HTTP请求都会启动一个独立的PHP进程或线程,请求结束后资源会被释放,包括数据库连接。这意味着每次请求都要重新连接数据库,效率较低。
长连接就是让这个数据库连接在请求结束后不立即关闭,而是保留在内存中,供后续请求复用。常见于常驻内存的PHP环境,比如使用Swoole、Workerman等扩展或框架时。
mysqli或PDO时开启持久连接(persistent connection),通过在DSN中添加&persistent=true或使用mysqlnd驱动支持的持久句柄。new Redis()并复用连接,避免频繁重连。以Swoole为例,在协程环境下使用长连接:
$server = new Swoole\HTTP\Server("127.0.0.1", 9501);
$server->on("request", function ($request, $response) {
// 复用数据库连接(需配合连接池)
$redis = new Swoole\Coroutine\Redis();
$res = $redis->connect('127.0.0.1', 6379);
$value = $redis->get('key');
$response->end("Value: " . $value);
});
$server->start();
注意:普通FPM模式下开启持久连接效果有限,因为底层仍受制于进程生命周期;真正发挥长连接优势需要运行在常驻内存的服务中。
基本上就这些。长连接的核心是“复用”,关键在于运行环境是否支持持久化执行。在现代PHP高性能服务中,结合协程与连接池使用长连接,是提升系统吞吐量的重要手段。