Estoy tratando de configurar un servidor web en un VPS. Mi problema es que el uso de memoria de los procesos php-cgi aumenta con el tiempo a pesar de que el sitio web no recibe ningún tráfico. (por el momento está detrás de un firewall)
El VPS tiene 360 MB de RAM. Estoy usando Debian Lenny 32bit y sus paquetes lighttpd y php5-cgi. Además de algunos cambios de configuración (enumerados a continuación), estoy usando la configuración de stock de Debian.
El sitio web está basado en Drupal. Usando el módulo de desarrollo de Drupal, puedo decir que el uso de memoria de los scripts PHP es menos de 20 KB en promedio, y nunca excede los 8 MB.
Aquí están las partes relevantes de la salida de ps aux
:
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
www-data 29871 0.0 1.7 54552 6368 ? Ss Aug12 0:00 /usr/bin/php-cgi
www-data 29873 0.0 7.4 65808 27468 ? S Aug12 0:00 /usr/bin/php-cgi
www-data 29874 0.0 3.7 55808 13736 ? S Aug12 0:00 /usr/bin/php-cgi
www-data 29875 0.0 4.3 58040 16204 ? S Aug12 0:00 /usr/bin/php-cgi
www-data 29876 0.0 4.4 57444 16288 ? S Aug12 0:00 /usr/bin/php-cgi
www-data 29877 0.0 1.7 54552 6368 ? Ss Aug12 0:00 /usr/bin/php-cgi
www-data 29879 0.0 9.6 67140 35684 ? S Aug12 0:26 /usr/bin/php-cgi
www-data 29880 0.0 6.6 59172 24492 ? S Aug12 0:23 /usr/bin/php-cgi
www-data 29881 0.0 7.1 59784 26388 ? S Aug12 0:22 /usr/bin/php-cgi
www-data 29882 0.0 7.4 60880 27440 ? S Aug12 0:23 /usr/bin/php-cgi
- ¿Es normal tener php-cgi tan grande?
- ¿Es posible estimar el uso de memoria php-cgi en función de la configuración?
- ¿Algún consejo para reducir el consumo de memoria de los procesos php-cgi?
La búsqueda de errores conocidos de pérdida de memoria no produjo nada relevante. Y me sorprendería si los paquetes / configuración predeterminados de Debian tuvieran una pérdida de memoria tan obvia. Otros usuarios en el mismo host no tienen este problema.
Lo que he hecho hasta ahora está configurado PHP_FCGI_MAX_REQUESTS
en un valor bajo para que los procesos php-cgi se reciclen rápidamente. Cuando uso ab
para simular una carga alta, esto funciona muy bien. Los procesos mueren rápidamente antes de crecer más de 10 MB. Sin embargo, bajo una carga de baja a media, todos los procesos crecen de manera constante (debido al equilibrio de carga) y la mayoría de ellos consumen 28 MB + simultáneamente, poniendo mi VPS en riesgo de intercambio. Tenga en cuenta que incluso sin ningún tipo de tráfico, los procesos crecen de manera constante.
Puedo reducir la cantidad de procesos php-cgi, pero esto parece más una solución que una solución. Me sorprendería si php-cgi normalmente creciera así.
Además, sumar los números RSS totales para los procesos php-cgi da:
$ ps -C php-cgi -o rss= | awk '{s+=$1}END{print s/1024}'
195.738
Sin embargo, free -m
da el siguiente resultado:
total used free shared buffers cached
Mem: 360 351 8 0 33 190
-/+ buffers/cache: 127 232
Swap: 255 0 255
- ¿Me estoy perdiendo de algo? ¿Cómo es que la memoria utilizada (sin buffers) es menor que la memoria residente total de los procesos php-cgi en el host?
Tengo las siguientes extensiones de PHP:
php5-cgi php5-common php5-curl php5-gd php5-mysql php5-xcache
xcache.size
está configurado en 24M. Solía ser 32M pero reducirlo no ayudó. xcache.var_size
se establece en 0. Los complementos restantes están utilizando la configuración estándar. Las páginas de administración de xcache muestran que xcache está utilizando menos de 1 MB.
PHP memory_limit
está configurado en 32M.
Aquí está mi configuración FastCGI:
fastcgi.server = ( ".php" =>
((
"bin-path" => "/usr/bin/php-cgi",
"socket" => "/tmp/php.socket",
"max-procs" => 2,
"idle-timeout" => 20,
"bin-environment" => (
"PHP_FCGI_CHILDREN" => "4",
"PHP_FCGI_MAX_REQUESTS" => "1000"
),
"bin-copy-environment" => (
"PATH", "SHELL", "USER"
),
"broken-scriptfilename" => "enable"
))
)
Estoy usando más o menos el stock lighttpd.conf
que se envía con Debian.
Avíseme si hay otros datos que pueda proporcionar.
Cualquier ayuda es apreciada. He estado tratando de solucionar esto por días. Me he quedado sin ideas.
Muchas veces, este tipo de problemas se debe a algún caché de código de operación, como XCache o debido a la extensión de PHP memcached.
fuente
Elimine las bibliotecas no utilizadas de /etc/php5/apache2/conf.d. Probablemente no necesite pdo.ini y pdo_mysq.ini o mysqli.ini. Esto le ahorrará unos pocos Mega de Ram
fuente