Mysql长连接
这篇技术文章直截了当地对比了MySQL的短连接与长连接。它指出,与每次请求都建立、用完即关的短连接不同,通过 `mysql_pconnect()` 建立的持久连接会在首次打开后被缓存,后续请求会尝试复用同一连接,即使调用 `mysql_close()` 也不会关闭底层连接。 文章进一步以Apache为例,剖析了长连接的复用机制:PHP本身没有连接池,但Apache的进程池结构使得一个子进程所持有的数据库连接,能够在其被回收后依然“附着”在该进程上,从而在下一个请求被该进程处理时得以重用。这解释了长连接在特定环境下如何提升效率。 然而,作者也指出了硬币的另一面。在高并发场景下,如果没有配合应用层的连接池管理,仅依赖Apache进程池来维持大量长连接,可能很快就会耗尽MySQL的 `max_connections` 配置,导致新请求无法响应。文章客观地评价,短连接在高并发下频繁建连同样存在问题,结论是:在没有专用连接池时,将Apache作为临时的连接池管理是一种可行方案;但若要彻底应对高并发压力,引入应用层连接池才是更健壮的思路。