Solución de Problemas con PHP y Nginx en Homestead | Error 502 Bad Gateway

Pedro Jiménez
2 min readJan 17, 2024

--

Introducción

Cuando trabajamos con Homestead y Vagrant en el desarrollo de aplicaciones PHP, podemos encontrarnos con errores comunes que pueden ser difíciles de diagnosticar y solucionar. Uno de estos errores es el “502 Bad Gateway” que ocurre cuando Nginx no puede comunicarse con el proceso de PHP-FPM. Este artículo proporciona una guía paso a paso para solucionar problemas de comunicación entre Nginx y PHP-FPM en un entorno Homestead.

Escenario

El error se manifiesta cuando Nginx intenta usar una versión incorrecta de PHP-FPM, por ejemplo, php8.2 cuando nuestra aplicación requiere php8.1. Este error es visible en los logs de Nginx y se presenta como una falla al conectar al socket de PHP-FPM.

Solución Paso a Paso

1. Revisar Logs de Nginx

Primero, es fundamental revisar los logs de Nginx para entender la naturaleza del error. Puedes encontrar estos logs en:

/var/log/nginx/homestead.test-error.log

Busca líneas que contengan “connect() to … php8.2-fpm.sock failed” para confirmar que se trata de un problema de conexión con PHP-FPM.

2. Corregir la Configuración de Nginx

Abre el archivo de configuración de tu sitio en Nginx, ubicado en:

/etc/nginx/sites-available/homestead.test

Busca la línea que contiene fastcgi_pass y modifícala para que apunte al socket correcto de PHP-FPM, por ejemplo:

fastcgi_pass unix:/var/run/php/php8.1-fpm.sock;

3. Verificar la Configuración de PHP-FPM

Asegúrate de que PHP-FPM para la versión requerida (en este caso php8.1) esté instalado y configurado correctamente. Verifica el estado del servicio con:

sudo systemctl status php8.1-fpm

Si el servicio no está activo, inícialo con:

sudo systemctl start php8.1-fpm

4. Reiniciar Servicios

Después de realizar los cambios necesarios, reinicia Nginx para que la nueva configuración tenga efecto:

sudo systemctl restart nginx

5. Probar la Conectividad

Con los cambios realizados, intenta acceder a tu sitio web con la URL configurada (en este caso, homestead.test). Si todo está configurado correctamente, el error 502 debería desaparecer.

Conclusión

Los errores de configuración son comunes cuando se trabaja con múltiples versiones de PHP. Es crucial asegurarse de que Nginx esté dirigido al proceso de PHP-FPM correcto. Al seguir los pasos detallados en este artículo, podrás diagnosticar y resolver problemas de comunicación entre Nginx y PHP-FPM en Homestead.

--

--