- Racó tècnic - http://www.racotecnic.com -

Configurar apache en modo mpm worker con php5 y fastcgi en ubuntu server

Quizás hayáis escuchado hablar del módulo mpm worker para apache [1]. Si no, yo os hago un breve resumen (corregidme si me equivoco).

Al compilar apache [2] podemos escoger el modo en que éste maneja los procesos del servidor. Según el modo que utilicemos se nos ofrecen ciertos pros y contras. Los pros del modo worker de apache es que es bastante más rápido que el modo prefork (que es el que viene habilitado por defecto). Los “contras” del modo worker es que el módulo de php para apache no es compatible con él y en lugar de ello deberemos utilizar el módulo de cgi.

A pesar de que he dicho lo de “al compilar”, no os preocupéis; podemos cambiar el modo en que funciona apache de manera rápida con aptitude.

Podéis encontrar más información y diferencias entre MPMs en: http://httpd.apache.org/docs/2.2/mpm.html [2].

Paquetes que necesitamos:

sudo apt-get install apache2 apache2-mpm-worker libapache2-mod-fcgid php5-cli php5-cgi

Una vez instalados, vamos a configurar apache para que ejecute ficheros php utilizando el módulo fastCGI:

sudo nano /etc/apache/conf.d/php

Pegad esto:

<Directory /usr/share>
        AddHandler fcgid-script .php
        FCGIWrapper /usr/lib/cgi-bin/php5 .php
        Options ExecCGI FollowSymlinks Indexes
</Directory>

<Files ~ (\.php)>
        AddHandler fcgid-script .php
        FCGIWrapper /usr/lib/cgi-bin/php5 .php
        Options +ExecCGI
        allow from all
</Files>

Nota: Al actualizar a php 5.4 he necesitado descomentar el último trozo del fichero de configuración /etc/apache2/mods-enabled/php5_cgi.conf ya que sinó me descargaba los ficheros php en lugar de ejecutarlos. El trozo al que me refiero es este:

ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
	AllowOverride None
	Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
	Order allow,deny
	Allow from all
</Directory>
Action application/x-httpd-php /cgi-bin/php5

Reiniciad apache:

sudo service apache2 restart

Y para acabar de finiquitar, provad un fichero php en vuestro servidor:

sudo echo '<?php phpinfo()' > /var/www/index.php

Si el parámetro no funciona simplemente cread un fichero index.php en vuestro webroot con el contenido

<?php phpinfo();

Accedéis a http://localhost [3] et voilà; Apache2 con módulo MPM-worker y PHP5 con FastCGI funcionando.

Si queréis verificar que realmente apache está funcionando en modo worker, podéis ejecutar el comando

:~$ apache2 -l
Compiled in modules:
  core.c
  mod_log_config.c
  mod_logio.c
  worker.c
  http_core.c
  mod_so.c

Fijaros que está cargado el módulo worker.c. Os recuerdo que por defecto apache viene con prefork.c por defecto.

Ahora vendría “lo wapo”: el fine tuning. Una de las mejores fuentes que encontraréis para saber como “tunear” vuestro apache es la propia documentación de apache:

httpd.apache.org/docs/2.2/mod/mpm_common.html [4]

E ir revisando con herramientas como top o ps los recursos que consume. Éste otro enlace puede que os dé alguna ayuda, a pesar de que está enfocado a funcionar con glassfish:

http://alexandru-ersenie.com/2011/09/19/performance-tuning-for-apache-worker-model-with-glassfish-application-server/ [5]

Además tendríais que hacerle algún tipo de test de estrés, claro.. pero ese es un tema como para hacer un artículo entero, así que yo lo dejo para otro día, pero os animo a que busquéis por google, que seguro que encontráis unas cuantas vías para “estresar” vuestro servidor.

Más información y fuentes:

PS. A todo esto.. todo el tutorial lo he hecho utilizando Ubuntu Server 12.04 x64 :)