El autor seleccionó la Electronic Frontier Foundation para recibir una donación como parte del programa Write for DOnations.
Apache y Nginx son dos servidores web de código abierto populares que se suelen utilizar con PHP. Puede ser útil ejecutar ambos en la misma máquina virtual al albergar múltiples sitios web con requisitos variados. La solución general para ejecutar dos servidores web en un solo sistema es usar varias direcciones IP o diferentes números de puerto.
Los servidores que tienen direcciones IPv4 e IPv6 pueden configurarse para servir sitios de Apache en un protocolo y sitios de Nginx en el otro, pero, actualmente, esto no resulta práctico, dado que la adopción de IPv6 por parte de los ISP todavía no está generalizada. Si bien tener un número de puerto diferente, como 81
o 8080
, para el segundo servidor web es otra solución, compartir URL con números de puerto (como http://example.com:81
) no siempre es razonable o ideal.
En este tutorial, procederá a configurar Nginx como servidor web y como proxy inverso para Apache en un solo servidor.
Dependiendo de la aplicación web, se pueden requerir cambios de código para mantener Apache al tanto del proxy inverso, en especial, cuando se configuran los sitios de SSL. Para evitar esto, instalará un módulo de Apache denominado mod_rpaf
que reescribe ciertas variables de entorno para que parezca que Apache está gestionando directamente solicitudes de clientes web.
Albergaremos cuatro nombres de dominio en un servidor. Nginx servirá dos de ellos: example.com
(el host virtual predeterminado) y sample.org
. Apache servirá los otros dos: foobar.net
y test.io
. También configuraremos Apache para que sirva aplicaciones de PHP usando PHP-FPM, que ofrece un mejor rendimiento que mod_php
.
Para completar este tutorial, necesitará lo siguiente:
Vamos a comenzar por instalar Apache y PHP-FPM.
Además de Apache y PHP-FPM, también instalaremos el módulo PHP FastCGI de Apache, libpache2-mod-fastcgi
, para admitir aplicaciones web FastCGI.
Primero, actualice su lista de paquetes para asegurarse de tener los paquetes más recientes.
- sudo apt update
A continuación, instale los paquetes de Apache y PHP-FPM:
- sudo apt install apache2 php-fpm
El módulo FastCGI Apache no está disponible en el repositorio de Ubuntu, por lo que debe descargarlo desde kernel.org e instalarlo usando el comando dpkg
.
- wget https://mirrors.edge.kernel.org/ubuntu/pool/multiverse/liba/libapache-mod-fastcgi/libapache2-mod-fastcgi_2.4.7~0910052141-1.2_amd64.deb
- sudo dpkg -i libapache2-mod-fastcgi_2.4.7~0910052141-1.2_amd64.deb
Luego, cambiemos la configuración predeterminada de Apache para usar PHP-FPM.
En este paso, cambiaremos el número de puerto de Apache a 8080
y lo configuraremos para que funcione con PHP-FPM usando el módulo mod_fastcgi
. Renombre al archivo de configuración ports.conf
de Apache:
- sudo mv /etc/apache2/ports.conf /etc/apache2/ports.conf.default
Cree un archivo ports.conf
nuevo con el puerto establecido en 8080
:
- echo "Listen 8080" | sudo tee /etc/apache2/ports.conf
Nota: en general, los servidores web se establecen para escuchar en 127.0.0.1:8080
al configurar un proxy inverso, pero al hacerlo, el valor de la variable de entorno SERVER_ADDR de PHP se establece en la dirección IP de bucle invertido en lugar de establecerse en la IP pública del servidor. Nuestro objetivo es configurar Apache de manera tal que sus sitios web no visualicen un proxy inverso delante suyo. Por lo tanto, lo configuraremos para escuchar en 8080
todas las direcciones IP.
A continuación, crearemos un archivo de host virtual para Apache. La <VirtualHost>
directiva en este archivo se establecerá para servir sitios únicamente en el puerto 8080
.
Desactive el host virtual predeterminado:
- sudo a2dissite 000-default
A continuación, cree un nuevo archivo de host virtual usando el sitio predeterminado existente:
- sudo cp /etc/apache2/sites-available/000-default.conf /etc/apache2/sites-available/001-default.conf
Ahora, abra el nuevo archivo de configuración:
- sudo nano /etc/apache2/sites-available/001-default.conf
Cambie el puerto de escucha a 8080
:
<VirtualHost *:8080>
ServerAdmin webmaster@localhost
DocumentRoot /var/www/html
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
Guarde el archivo y active el nuevo archivo de configuración:
- sudo a2ensite 001-default
Luego, vuelva a cargar Apache:
- sudo systemctl reload apache2
Verifique que, ahora, Apache escuche en 8080
:
- sudo netstat -tlpn
El resultado debería verse como el siguiente ejemplo, con apache2
escuchando en 8080
:
OutputActive Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1086/sshd
tcp6 0 0 :::8080 :::* LISTEN 4678/apache2
tcp6 0 0 :::22 :::* LISTEN 1086/sshd
Una vez verifique que Apache está escuchando en el puerto correcto, puede configurar la compatibilidad con PHP y FastCGI.
Apache sirve páginas de PHP usando mod_php
por defecto, pero requiere de configuración adicional para funcionar con PHP-FPM.
Nota: si está probando este tutorial en una instalación de LAMP con mod_php, primero, desactívela con sudo a2dismod php7.2
.
Vamos a añadir un bloque de configuración para mod_fastcgi
que depende de mod_action
. mod_action
está desactivado por defecto, por lo que, primero, debemos habilitarlo:
- sudo a2enmod actions
Cambie el nombre del archivo de configuración FastCGI:
- sudo mv /etc/apache2/mods-enabled/fastcgi.conf /etc/apache2/mods-enabled/fastcgi.conf.default
Cree un nuevo archivo de configuración:
- sudo nano /etc/apache2/mods-enabled/fastcgi.conf
Añada las siguientes directivas al archivo para transmitir solicitudes de archivos .php
al socket PHP-FPM UNIX:
<IfModule mod_fastcgi.c>
AddHandler fastcgi-script .fcgi
FastCgiIpcDir /var/lib/apache2/fastcgi
AddType application/x-httpd-fastphp .php
Action application/x-httpd-fastphp /php-fcgi
Alias /php-fcgi /usr/lib/cgi-bin/php-fcgi
FastCgiExternalServer /usr/lib/cgi-bin/php-fcgi -socket /run/php/php7.2-fpm.sock -pass-header Authorization
<Directory /usr/lib/cgi-bin>
Require all granted
</Directory>
</IfModule>
Guarde los cambios y realice una prueba de configuración:
- sudo apachectl -t
Vuelva a cargar Apache si aparece el mensaje Syntax OK:
- sudo systemctl reload apache2
Si ve la advertencia Could not reliably determine the server's fully qualified domain name, using 127.0.1.1. Set the 'ServerName' directive globally to suppress this message.
, puede ignorarlo de forma segura por ahora. Configuraremos los nombres de servidor más adelante.
Ahora, asegúrese de que podamos servir PHP desde Apache.
Vamos a asegurarnos de que PHP funcione al crear un archivo phpinfo()
y acceder a él desde un navegador.
Cree el archivo /var/www/html/info.php
que contiene una llamada a la función phpinfo
:
- echo "<?php phpinfo(); ?>" | sudo tee /var/www/html/info.php
Para ver el archivo en un navegador, vaya a http://your_server_ip:8080/info.php
. Esto le dará una lista de los ajustes de configuración que PHP está usando. Visualizará un resultado similar a esto:
En la parte superior de la página, verifique que Server API diga FPM/FastCGI. A los dos tercios de la página, aproximadamente, la sección PHP Variables le indicará que **SERVER_SOFTWARE **es Apache en Ubuntu. Esto confirma que mod_fastcgi
está activo y que Apache está usando PHP-FPM para procesar archivos PHP.
Vamos a crear archivos de host virtuales de Apache para los dominios foobar.net
y test.io
. Para hacerlo, primero, crearemos directorios root de documentos para ambos sitios y colocaremos algunos archivos predeterminados en ellos para poder probar nuestra configuración fácilmente.
Primero, cree los directorios root de documentos:
- sudo mkdir -v /var/www/foobar.net /var/www/test.io
A continuación, cree un archivo de índice
para cada sitio:
- echo "<h1 style='color: green;'>Foo Bar</h1>" | sudo tee /var/www/foobar.net/index.html
- echo "<h1 style='color: red;'>Test IO</h1>" | sudo tee /var/www/test.io/index.html
Luego, cree un archivo phpinfo()
para cada sitio para que podamos comprobar que PHP esté configurado correctamente.
- echo "<?php phpinfo(); ?>" | sudo tee /var/www/foobar.net/info.php
- echo "<?php phpinfo(); ?>" | sudo tee /var/www/test.io/info.php
Ahora, cree el archivo de host virtual para el dominio foobar.net
:
- sudo nano /etc/apache2/sites-available/foobar.net.conf
Añada el siguiente código al archivo para definir el host:
<VirtualHost *:8080>
ServerName foobar.net
ServerAlias www.foobar.net
DocumentRoot /var/www/foobar.net
<Directory /var/www/foobar.net>
AllowOverride All
</Directory>
</VirtualHost>
La línea AllowOverride All
habilita la compatibilidad con .htaccess
.
Estas son solo las directivas más básicas. Para obtener una guía completa sobre la configuración de hosts virtuales en Apache, consulte Cómo configurar hosts virtuales de Apache en Ubuntu 16.04.
Guarde y cierre el archivo. A continuación, cree una configuración similar para test.io
. Primero, cree el archivo:
- sudo nano /etc/apache2/sites-available/test.io.conf
A continuación, añada la configuración al archivo:
<VirtualHost *:8080>
ServerName test.io
ServerAlias www.test.io
DocumentRoot /var/www/test.io
<Directory /var/www/test.io>
AllowOverride All
</Directory>
</VirtualHost>
Guarde el archivo y salga del editor.
Ahora que ambos hosts virtuales de Apache están configurados, habilite los sitios usando el comando a2ensite
. Esto crea un enlace simbólico al archivo de host virtual en el directorio sites-enabled
:
- sudo a2ensite foobar.net
- sudo a2ensite test.io
Revise Apache para verificar que no haya errores de configuración nuevamente:
- sudo apachectl -t
Visualizará el mensaje **Syntax OK **si no hay errores. Si ve algo distinto, revise la configuración y vuelva a intentarlo.
Vuelva a cargar Apache para aplicar los cambios una vez que su configuración esté libre de errores:
- sudo systemctl reload apache2
Para confirmar que los sitios están funcionando, abra http://foobar.net:8080
y http://test.io:8080
en su navegador y verifique que cada sitio muestre su archivo index.html.
Visualizará los siguientes resultados:
Además, asegúrese de que PHP está funcionando al acceder a los archivos **info.php **de cada sitio. Visite http://foobar.net:8080/info.php
y http://test.io:8080/info.php
en su navegador.
Visualizará la misma lista de especificaciones de configuración de PHP en cada sitio que vio en el Paso 4.
Ahora, tenemos dos sitios web albergados en Apache en el puerto 8080
. Procedamos a configurar Nginx a continuación.
En este paso, instalaremos Nginx y configuraremos los dominios exemple.com
y sample.com
como hosts virtuales de Nginx. Para obtener una guía completa sobre la configuración de hosts virtuales en Nginx, consulte Cómo configurar bloques de servidor Nginx (hosts virtuales) en Ubuntu 18.04.
Instale Nginx usando el gestor de paquetes:
- sudo apt install nginx
A continuación, elimine el enlace simbólico del host virtual predeterminado, dado que no lo usaremos más:
- sudo rm /etc/nginx/sites-enabled/default
Crearemos nuestro propio sitio predeterminado más adelante (example.com
).
Ahora, crearemos hosts virtuales para Nginx usando el mismo procedimiento que usamos para Apache. Primero, cree directorios root de documentos para ambos sitios web:
- sudo mkdir -v /usr/share/nginx/example.com /usr/share/nginx/sample.org
Mantendremos los sitios web de Nginx en /usr/share/nginx
, que es donde Nginx los quiere por defecto. Podría ponerlos en /var/www/html
con los sitios de Apache, pero esta separación puede ayudarlo a asociar sitios con Nginx.
Tal como hizo con los hosts virtuales de Apache, cree archivos index
y phpinfo()
para probar después de completar la configuración:
- echo "<h1 style='color: green;'>Example.com</h1>" | sudo tee /usr/share/nginx/example.com/index.html
- echo "<h1 style='color: red;'>Sample.org</h1>" | sudo tee /usr/share/nginx/sample.org/index.html
- echo "<?php phpinfo(); ?>" | sudo tee /usr/share/nginx/example.com/info.php
- echo "<?php phpinfo(); ?>" | sudo tee /usr/share/nginx/sample.org/info.php
Ahora, cree un archivo de host virtual para el dominio example.com
:
- sudo nano /etc/nginx/sites-available/example.com
Nginx llama a áreas server {. . .}
de **bloques de servidor **de un archivo de configuración. Cree un bloque de servidor para el host virtual primario, example.com
. La directiva de configuración default_server
lo convierte en el host virtual predeterminado que procesa solicitudes HTTP que no coinciden con ningún otro host virtual.
server {
listen 80 default_server;
root /usr/share/nginx/example.com;
index index.php index.html index.htm;
server_name example.com www.example.com;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
fastcgi_pass unix:/run/php/php7.2-fpm.sock;
include snippets/fastcgi-php.conf;
}
}
Guarde y cierre el archivo. Ahora, cree un archivo de host virtual para el segundo dominio de Nginx, sample.org
:
- sudo nano etc/nginx/sites-available/sample.org
Añada lo siguiente al archivo:
server {
root /usr/share/nginx/sample.org;
index index.php index.html index.htm;
server_name sample.org www.sample.org;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
fastcgi_pass unix:/run/php/php7.2-fpm.sock;
include snippets/fastcgi-php.conf;
}
}
Guarde y cierre el archivo.
A continuación, habilite ambos sitios creando enlaces simbólicos al directorio sites-enabled
:
- sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/example.com
- sudo ln -s /etc/nginx/sites-available/sample.org /etc/nginx/sites-enabled/sample.org
A continuación, pruebe la configuración de Nginx para asegurarse de que no haya problemas de configuración:
- sudo nginx -t
Luego, si no hay errores, vuelva a cargar Nginx:
- sudo systemctl reload nginx
Ahora, acceda al archivo phpinfo()
de sus hosts virtuales de Nginx en un navegador web al visitar los sitios http://example.com/info.php
y http://sample.org/info.php
. Vuelva a buscar en las secciones de PHP Variables.
[“SERVER_SOFTWARE” ] debe decir nginx
, lo que indica que Nginx sirvió directamente los archivos.[ “DOCUMENT_ROOT” ] debe apuntar al directorio que creó anteriormente en este paso para cada sitio de Nginx.
En este momento, ya instalamos Nginx y creamos dos hosts virtuales. A continuación, configuraremos Nginx para las solicitudes de proxy destinadas a dominios albergados en Apache.
Vamos a crear un host virtual de Nginx adicional con múltiples nombres de dominio en las directivas de server_name
. Las solicitudes de estos nombres de dominio se redirigirán mediante proxy a Apache.
Cree un archivo de host virtual de Nginx nuevo para reenviar solicitudes a Apache:
- sudo nano /etc/nginx/sites-available/apache
Añada el siguiente bloque de código que especifica los nombres de ambos dominios de host virtuales de Apache y redirige sus solicitudes a Apache mediante proxy. Recuerde usar la dirección IP pública en proxy_pass
:
server {
listen 80;
server_name foobar.net www.foobar.net test.io www.test.io;
location / {
proxy_pass http://your_server_ip:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
Guarde el archivo y habilite este host virtual nuevo al crear un enlace simbólico:
- sudo ln -s /etc/nginx/sites-available/apache /etc/nginx/sites-enabled/apache
Pruebe la configuración para asegurarse de que no haya errores:
- sudo nginx -t
Si no hay errores, vuelva a cargar Nginx:
- sudo systemctl reload nginx
Abra el navegador y acceda a la URL http://foobar.net/info.php
. Desplácese hacia abajo a la sección de **PHP Variables **y verifique los valores mostrados.
Las variables **SERVER_SOFTWARE **y **DOCUMENT_ROOT **confirman que Apache gestionó esta solicitud. Nginx añadió las variables HTTP_X_REAL_IP y HTTP_X_FORWARDED_FOR, y deben mostrar la dirección IP pública del equipo que está utilizando para acceder a la URL.
Configuramos Nginx correctamente para que redirija solicitudes de dominios específicos a Apache mediante proxy. A continuación, configuremos Apache para establecer la variable REMOTE_ADDR
como si estuviera gestionando directamente estas solicitudes.
En este paso, instalará un módulo de Apache llamado mod\_rpaf
que reescribe los valores de REMOTE_ADDR, HTTPS y HTTP_PORT en función de los valores proporcionados por un proxy inverso. Sin este módulo, algunas aplicaciones de PHP requerirían cambios de código para funcionar sin problemas detrás de un proxy. Este módulo está presente en el repositorio de Ubuntu como libpache2-mod-rpaf
, pero está obsoleto y no admite ciertas directivas de configuración. En su lugar, lo instalaremos desde la fuente.
Instale los paquetes necesarios para crear el módulo:
- sudo apt install unzip build-essential apache2-dev
Descargue la última versión estable de GitHub:
- wget https://github.com/gnif/mod_rpaf/archive/stable.zip
Extraiga el archivo descargado:
- unzip stable.zip
Cambie al directorio nuevo que contiene los archivos:
- cd mod_rpaf-stable
Compile e instale el módulo:
- make
- sudo make install
A continuación, cree un archivo en el directorio mods-available
que cargará el módulo rpaf
:
- sudo nano /etc/apache2/mods-available/rpaf.load
Añada el siguiente código al archivo para cargar el módulo:
LoadModule rpaf_module /usr/lib/apache2/modules/mod_rpaf.so
Guarde el archivo y salga del editor.
Cree otro archivo en este directorio llamado rpaf.conf
que contendrá las directivas de configuración para mod_rpaf
:
- sudo nano /etc/apache2/mods-available/rpaf.conf
Añada el siguiente bloque de código para configurar mod_rpaf
, asegurándose de especificar la dirección IP de su servidor:
<IfModule mod_rpaf.c>
RPAF_Enable On
RPAF_Header X-Real-Ip
RPAF_ProxyIPs your_server_ip
RPAF_SetHostName On
RPAF_SetHTTPS On
RPAF_SetPort On
</IfModule>
Esta es una breve descripción de cada directiva. Consulte el archivo README de mod_rpaf
para obtener más información.
ServerName
y ServerAlias
funcionen.HTTPS
en función del valor contenido en X-Forwarded-Proto
.SERVER_PORT
. Es útil para cuando Apache está detrás de un proxy SSL.Guarde rpaf.conf
y habilite el módulo:
- sudo a2enmod rpaf
Esto crea enlaces simbólicos de los archivos rpaf.load
y rpaf.conf
en el directorio mods-enabled
. Ahora, realice una prueba de configuración:
- sudo apachectl -t
Vuelva a cargar Apache si no hay errores:
- sudo systemctl reload apache2
Acceda a las páginas phpinfo()
http://foobar.net/info.php
y http://test.io/info.php
en su navegador y verifique la sección PHP Variables. La variable REMOTE_ADDR, ahora, también corresponderá a la de la dirección IP pública de su equipo local.`
Ahora, configuremos el cifrado TLS/SSL para cada sitio.
En este paso, configuraremos certificados TLS/SSL para ambos dominios albergados en Apache. Obtendremos los certificados a través de Let’s Encrypt. Nginx admite la terminación SSL, por lo que podemos configurar SSL sin modificar los archivos de configuración de Apache. El módulo mod_rpaf
se asegura de que las variables de entorno requeridas estén establecidas en Apache para que las aplicaciones funcionen sin problemas detrás de un proxy inverso SSL.
Primero, separaremos los bloques server {...}
de ambos dominios para que cada uno de ellos pueda tener sus propios certificados SSL. Abra el archivo /etc/nginx/sites-available/apache
en su editor:
- sudo nano /etc/nginx/sites-available/apache
Modifique el archivo para que se vea de la siguiente manera, con foobar.net
y test.io
en sus propios bloques server
:
server {
listen 80;
server_name foobar.net www.foobar.net;
location / {
proxy_pass http://your_server_ip:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
server {
listen 80;
server_name test.io www.test.io;
location / {
proxy_pass http://your_server_ip:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
Utilizaremos Certbot para generar nuestros certificados TLS/SSL. Su complemento de Nginx se encargará de reconfigurar Nginx y volver a cargar la configuración cuando sea necesario.
Primero, añada el repositorio oficial de Certbot:
- sudo add-apt-repository ppa:certbot/certbot
Presione ENTER
cuando se le indique para confirmar que desea añadir el repositorio nuevo. A continuación, actualice la lista de paquetes para obtener la información de paquetes del repositorio nuevo:
- sudo apt update
A continuación, instale el paquete Nginx de Certbot con apt
:
- sudo apt install python-certbot-nginx
Una vez instalado, utilice el comando certbot
para generar los certificados para foobar.net
y www.foobar.net
:
- sudo certbot --nginx -d foobar.net -d www.foobar.net
Este comando le indica a Certbot que use el complemento nginx
, utilizando -d
para especificar los nombres para los que deseamos que el certificado sea válido.
Si es la primera vez que ejecuta certbot
, se le pedirá que ingrese una dirección de correo electrónico y que acepte las condiciones de servicio. A continuación, certbot
se comunicará con el servidor de Let’s Encrypt, y, luego, realizará una comprobación para verificar que usted controle el dominio para el que está solicitando un certificado.
Luego, Certbot le preguntará cómo desea configurar sus ajustes de HTTPS:
OutputPlease choose whether or not to redirect HTTP traffic to HTTPS, removing HTTP access.
-------------------------------------------------------------------------------
1: No redirect - Make no further changes to the webserver configuration.
2: Redirect - Make all requests redirect to secure HTTPS access. Choose this for
new sites, or if you're confident your site works on HTTPS. You can undo this
change by editing your web server's configuration.
-------------------------------------------------------------------------------
Select the appropriate number [1-2] then [enter] (press 'c' to cancel):
Seleccione su elección y presione ENTER
. La configuración se actualizará y Nginx se volverá a cargar para recopilar los ajustes nuevos.
Ahora, ejecute el comando para el segundo dominio:
- sudo certbot --nginx -d test.io -d www.test.io
Acceda a uno de los dominios de Apache en su navegador utilizando https://
prefix; visite https://foobar.net/info.php
y verá esto:
Busque en la sección PHP Variables. La variable SERVER_PORT se estableció en 443 y HTTPS, en on, como si se hubiese accedido a Apache directamente desde HTTPS. Con estas variables establecidas, las aplicaciones de PHP no requieren una configuración especial para funcionar detrás de un proxy inverso.
Ahora, desactive el acceso directo a Apache.
Dado que Apache está escuchando en el puerto 8080
, en la dirección IP pública, es accesible para todos. Puede bloquearse al utilizar el siguiente comando IPtables en su conjunto de reglas de firewall.
- sudo iptables -I INPUT -p tcp --dport 8080 ! -s your_server_ip -j REJECT --reject-with tcp-reset
Asegúrese de usar la dirección IP de su servidor en lugar del ejemplo en rojo. Una vez que el puerto 8080
esté bloqueado en su firewall, compruebe que sea imposible acceder a Apache desde este. Abra su navegador web e intente acceder a uno de los nombres de dominio de Apache en el puerto 8080
. Por ejemplo, http://example.com:8080
El navegador debería mostrar el mensaje de error “Unable to connect” o “Webpage is not available”. Con la opción IPtables tcp-reset
implementada, una persona externa no vería ninguna diferencia entre el puerto 8080
y un puerto que no tiene ningún servicio.
Nota: por defecto, las reglas de IPtables no se mantienen al reiniciar el sistema. Hay varias formas de preservar las reglas de IPtables, pero lo más fácil es usar iptables-persistent
en el repositorio de Ubuntu. Estudie este artículo para obtener más información sobre cómo configurar IPTables.
Ahora, configuremos Nginx para servir archivos estáticos para los sitios de Apache.
Cuando Nginx redirige solicitudes de dominios de Apache mediante proxy, envía cada solicitud de archivo de esos dominios a Apache. Nginx es más rápido que Apache en servir archivos estáticos como imágenes, JavaScript y hojas de estilo. Por lo tanto, procederemos a configurar el archivo de host virtual apache
de Nginx para servir directamente archivos estáticos, pero enviar solicitudes de PHP a Apache.
Abra el archivo /etc/nginx/sites-available/apache
en su editor:
- sudo nano /etc/nginx/sites-available/apache
Deberá añadir dos bloques de location
adicionales a cada bloque de servidor, y modificar las secciones de location
existentes. Además, deberá indicarle a Nginx dónde encontrar los archivos estáticos de cada sitio.
Si decidió no usar certificados SSL y TLS, modifique su archivo para que se vea así:
server {
listen 80;
server_name test.io www.test.io;
root /var/www/test.io;
index index.php index.htm index.html;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
proxy_pass http://your_server_ip:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
location ~ /\.ht {
deny all;
}
}
server {
listen 80;
server_name foobar.net www.foobar.net;
root /var/www/foobar.net;
index index.php index.htm index.html;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
proxy_pass http://your_ip_address:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
location ~ /\.ht {
deny all;
}
}
Si también desea que esté disponible HTTPS, utilice la siguiente configuración en su lugar:
server {
listen 80;
server_name test.io www.test.io;
root /var/www/test.io;
index index.php index.htm index.html;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
proxy_pass http://your_server_ip:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
location ~ /\.ht {
deny all;
}
listen 443 ssl;
ssl_certificate /etc/letsencrypt/live/test.io/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/test.io/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf;
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
}
server {
listen 80;
server_name foobar.net www.foobar.net;
root /var/www/foobar.net;
index index.php index.htm index.html;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
proxy_pass http://your_ip_address:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
location ~ /\.ht {
deny all;
}
listen 443 ssl;
ssl_certificate /etc/letsencrypt/live/foobar.net/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/foobar.net/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf;
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
}
La directiva try_files
hace que Nginx busque archivos en el root de documentos y los sirva directamente. Si el archivo tiene una extensión .php
, la solicitud se transmite a Apache. Aunque el archivo no se encuentre en el root de documentos, la solicitud se transmite a Apache para que características de la aplicación, como permalinks, funcionen sin problemas.
Advertencia: la directiva location ~ /\.ht
es muy importante; impide que Nginx sirva los contenidos de los archivos de configuración de Apache, como.htaccess
y .htpasswd
, que contienen información sensible.
Guarde el archivo y realice una prueba de configuración:
- sudo nginx -t
Vuelva a cargar Nginx si la prueba resulta exitosa:
- sudo service nginx reload
Para verificar que todo funcione, puede examinar los archivos de registro de Apache en /var/log/apache2
y consultar las solicitudes GET
de los archivos info.php
de test.io
y foobar.net
. Utilice el comando tail
para ver las últimas líneas del archivo, y use el botón -f
para ver si hay cambios en el archivo:
- sudo tail -f /var/log/apache2/other_vhosts_access.log
Ahora, visite http://test.io/info.php
en su navegador y, luego, verifique la salida del registro. Verá que Apache está contestando:
Output test.io:80 your_server_ip - - [01/Jul/2016:18:18:34 -0400] "GET /info.php HTTP/1.0" 200 20414 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.111 Safari/537.36"
A continuación, visite la página index.html
de cada sitio y no verá entradas de registro de Apache. Nginx las está sirviendo.
Cuando haya terminado de observar el archivo de registro, presione CTRL+C
para dejar de seguirlo.
Con esta configuración, Apache no podrá restringir el acceso a archivos estáticos. El control de acceso de los archivos estáticos deberá configurarse en el archivo de host virtual apache
de Nginx, pero eso va más allá del alcance de este tutorial.
Ahora, tiene un servidor Ubuntu con Nginx sirviendo example.com
y sample.org
, y Apache sirviendo foobar.net
y test.io
. Aunque Nginx está actuando como proxy inverso de Apache, el servicio de proxy de Nginx es transparente y las conexiones a los dominios de Apache parecen servirse directamente desde Apache. Puede usar este método para servir sitios seguros y estáticos.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Hi,
Thanks for the tutorial! I have configured all the things like you say… but, I have a problem with a clean wordpress installation… I can login to the wp-admin area without problems, but, when I try to navigate the frontside… the browser enters a continuous loop (301 document / redirection) and finish then showing ERR_TO_MANY_REDIRECTS
You can see the problem here: http://destinopunilla.com.ar/wordpress/wordpress/
But, I can load ok a simple php file, you can see here: http://destinopunilla.com.ar/sitioweb/verphpdestino2.php
Mi nginx server for the domain contain this:
server {
}
The port of apache was changed to listen 8080, and my virtualhost of apache for the domain actually contain this:
<VirtualHost 127.0.0.1:8080> SuexecUserGroup “#1002” “#1002” ServerName destinopunilla.com.ar ServerAlias www.destinopunilla.com.ar ServerAlias mail.destinopunilla.com.ar ServerAlias webmail.destinopunilla.com.ar ServerAlias admin.destinopunilla.com.ar DocumentRoot /home/destinopunilla/public_html ErrorLog /var/log/virtualmin/destinopunilla.com.ar_error_log CustomLog /var/log/virtualmin/destinopunilla.com.ar_access_log combined DirectoryIndex index.html index.htm index.php index.php4 index.php5 <Directory /home/destinopunilla/public_html> Options -Indexes +IncludesNOEXEC +SymLinksIfOwnerMatch +ExecCGI allow from all AllowOverride All Options=ExecCGI,Includes,IncludesNOEXEC,Indexes,MultiViews,SymLinksIfOwnerMatch Require all granted AddType application/x-httpd-php .php AddHandler fcgid-script .php AddHandler fcgid-script .php7.4 FCGIWrapper /home/destinopunilla/fcgi-bin/php7.4.fcgi .php FCGIWrapper /home/destinopunilla/fcgi-bin/php7.4.fcgi .php7.4 </Directory> </VirtualHost>
Can you tell me where could be the missconfiguration to work ok with a wordpress frontside?
segui los pasos pero al final mi web no redirecciona como debe ser y queda así example.com.co:81 no deberia mostrar el puerto y no toma el ssl al hacer la instalacion con cerbot.
Hola, al configurar el vhost para los sitios en apache con SSL /etc/nginx/sites-available/apache obtengo el siguiente mensaje y URl al acceder al sitio:
La página no se está redireccionando apropiadamente
https://mi_dominio.dev/:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080:8080
Espero puedan orientarme Gracias!