Después de mucho buscar, finalmente he encontrado una solución.
No soy muy escritor, así que haré todo lo posible para que esto sea lo más conciso posible.
Por lo que pude encontrar, hay 2 posibles soluciones:
Retransmisión SQL
http://sqlrelay.sourceforge.net/
Esto hace exactamente lo que pidió la pregunta, y un montón más. No entraré en demasiados detalles sobre lo que pude averiguar sobre esto, pero mencionaré que no era una solución viable ya que no es transparente. Lo que significa que el flujo es el siguiente:
PHP -> Queries -> SQL Relay Extension -> SQL Relay -> Externally hosted MySQL
Entonces, esto habría implicado reescribir todo nuestro código de mysql a sql relay. No es una opción en nuestro caso.
Dicho todo esto, si alguien está planeando un nuevo proyecto a gran escala que requiera cualquiera de las numerosas características que tiene SQL Relay, suena hermoso.
Proxy Mysql
http://forge.mysql.com/wiki/MySQL_Proxy
Esta es la solución que terminamos usando.
La clave para hacer que esto haga lo que queremos que haga es el script LUA de agrupación para el proxy mysql.
Esta extensión LUA se puede encontrar en:
https://github.com/cwarden/mysql-proxy/blob/315ab806bb95b8223f5afd3d238eff2a40af03d8/lib/ro-pooling.lua
Sin entrar en demasiados detalles, aquí hay algunas estadísticas básicas ... Ten en cuenta que esto se prueba con un tiempo de uso BAJO:
[root@HOSTNAME etc]# netstat -na | grep ":3306 " | grep TIME_WAIT | wc
6433 38598 572537
Después de cambiar a mysql-proxy y dejar que las cosas se resuelvan:
[root@HOSTNAME etc]# netstat -na | grep ":3306 " | grep TIME_WAIT | wc
32 192 2848
Como puede ver claramente, los puertos TIME_WAIT a mysql se han reducido a casi ninguno.
Las conexiones ahora son de hecho persistentes SIN usar mysql_pconnect / mysqli_connect (... p: hostname ...).
Vale la pena mencionar que parece haber algunas configuraciones configurables cerca de la parte superior del script lua de pooler.
min_idle_connections locales
y
max_idle_connections locales
Estos parecen ser bastante explicativos. Excepto que: Parece que cada combinación de nombre de usuario (y contraseña no probada ... probablemente no) crea su propio conjunto de conexiones persistentes.
Entonces multiplique max_idle_connections por la cantidad de usuarios únicos de mysql que se conectarán a la base de datos. Y eso debería darte una idea de cuántas conexiones inactivas terminarás teniendo.
Entonces, permítanme reiterarlo para que esta pequeña propaganda llegue a algunas palabras clave para aquellos que buscan a través de Google:
Cuando se usa PHP, ¿es posible tener conexiones persistentes de mysql SIN mysql_pconnect?
Sí, esto se puede hacer a través de SQL Relay si no le importa reconstruir la mayoría de su código para canalizar sus consultas a través de su extensión O de forma transparente usando mysql-proxy con el script ro-pooling.lua.
Hemos estado esperando algo como esto durante aproximadamente un año.
¡DISFRUTAR!
mysql_pconnect
e iniciar cada conexión con algunas "funciones de limpieza"?