Este tutorial le mostrará cómo instalar la pila LEMP (Nginx, MariaDB y PHP7.4) en Ubuntu 20.04. Una pila de software es un conjunto de herramientas de software agrupadas. LEMP significa Linux, Nginx (Engine-X), MariaDB/MySQL y PHP, todos los cuales son de código abierto y de uso gratuito. Es la pila de software más común que impulsa sitios web dinámicos y aplicaciones web. Linux es el sistema operativo; Nginx es el servidor web; MariaDB/MySQL es el servidor de la base de datos y PHP es el lenguaje de secuencias de comandos del lado del servidor responsable de generar páginas web dinámicas.
Requisitos
Para seguir este tutorial, necesita un sistema operativo Ubuntu 20.04 ejecutándose en su computadora local o en un servidor remoto.
Si está buscando un VPS (servidor privado virtual), puede registrar una cuenta en DigitalOcean a través de este enlace especial para obtener $ 50 de crédito gratis. (Solo para nuevos usuarios). Si ya es usuario de DigitalOcean, puede registrar una cuenta en Vultr a través de este enlace especial para obtener $50 de crédito gratis (solo para nuevos usuarios).
Y si necesita configurar la pila LEMP con un nombre de dominio, recomiendo comprar nombres de dominio de NameCheap porque el precio es bajo y brindan protección de privacidad whois gratis de por vida.
Paso 1:Actualizar paquetes de software
Antes de instalar la pila LEMP, es una buena práctica actualizar el repositorio y los paquetes de software ejecutando los siguientes comandos en su sistema operativo Ubuntu 20.04.
sudo apt update sudo apt upgrade
Paso 2:Instalar el servidor web Nginx
Nginx es un servidor web de alto rendimiento y muy popular en estos días. También se puede utilizar como proxy inverso y servidor de almacenamiento en caché. Ingrese el siguiente comando para instalar el servidor web Nginx.
sudo apt install nginx
Una vez instalado, podemos permitir que Nginx se inicie automáticamente en el momento del arranque ejecutando el siguiente comando.
sudo systemctl enable nginx
Luego inicie Nginx con este comando:
sudo systemctl start nginx
Ahora comprueba su estado.
sudo systemctl status nginx
Salida:
● nginx.service - A high performance web server and a reverse proxy server Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled) Active: active (running) since Fri 2020-04-10 14:11:43 UTC; 3s ago Docs: man:nginx(8) Process: 8533 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS) Process: 8545 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS) Main PID: 8549 (nginx) Tasks: 3 (limit: 9451) Memory: 3.9M CGroup: /system.slice/nginx.service ├─8549 nginx: master process /usr/sbin/nginx -g daemon on; master_process on; ├─8550 nginx: worker process └─8551 nginx: worker process
“Habilitado ” indica que el inicio automático en el momento del arranque está habilitado y podemos ver que Nginx se está ejecutando. También puede ver cuánta RAM está utilizando Nginx a partir de la salida. Si el comando anterior no se cierra inmediatamente después de ejecutarse. Tienes que pulsar “q ” para que se cierre.
Verifique la versión de Nginx.
nginx -v
Salida:
nginx version: nginx/1.17.9 (Ubuntu)
Ahora escriba la dirección IP pública de su servidor Ubuntu 20.04 en la barra de direcciones del navegador. Debería ver la página web "Bienvenido a Nginx", lo que significa que el servidor web Nginx se está ejecutando correctamente. Si está instalando LEMP en su computadora Ubuntu 20.04 local, escriba 127.0.0.1
o localhost
en la barra de direcciones del navegador.
Si la conexión se rechaza o no se completa, es posible que haya un firewall que impida las solicitudes entrantes al puerto TCP 80. Si está utilizando el firewall de iptables, debe ejecutar el siguiente comando para abrir el puerto TCP 80.
sudo iptables -I INPUT -p tcp --dport 80 -j ACCEPT
Si está utilizando el firewall UFW, ejecute este comando para abrir el puerto TCP 80.
sudo ufw allow http
Finalmente, necesitamos hacer www-data
(usuario de Nginx) como propietario del directorio web. De forma predeterminada, es propiedad del usuario root.
sudo chown www-data:www-data /usr/share/nginx/html -R
Paso 3:Instale el servidor de base de datos MariaDB
MariaDB es un reemplazo directo para MySQL. Está desarrollado por antiguos miembros del equipo de MySQL que están preocupados de que Oracle pueda convertir a MySQL en un producto de código cerrado. Ingrese el siguiente comando para instalar MariaDB en Ubuntu 20.04.
sudo apt install mariadb-server mariadb-client
Una vez instalado, el servidor MariaDB debería iniciarse automáticamente. Usa systemctl para comprobar su estado.
systemctl status mariadb
Salida:
● mariadb.service - MariaDB 10.3.22 database server Loaded: loaded (/lib/systemd/system/mariadb.service; enabled; vendor preset: enabled) Active: active (running) since Fri 2020-04-10 14:19:16 UTC; 18s ago Docs: man:mysqld(8) https://mariadb.com/kb/en/library/systemd/ Main PID: 9161 (mysqld) Status: "Taking your SQL requests now..." Tasks: 31 (limit: 9451) Memory: 64.7M CGroup: /system.slice/mariadb.service └─9161 /usr/sbin/mysqld
Si no se está ejecutando, inícielo con este comando:
sudo systemctl start mariadb
Para permitir que MariaDB se inicie automáticamente en el momento del arranque, ejecute
sudo systemctl enable mariadb
Ahora ejecute el script de seguridad posterior a la instalación.
sudo mysql_secure_installation
Cuando le pida que ingrese la contraseña raíz de MariaDB, presione la tecla Intro ya que la contraseña raíz aún no está configurada. Luego ingrese y para establecer la contraseña raíz para el servidor MariaDB.
A continuación, puede presionar Entrar para responder a todas las preguntas restantes, lo que eliminará al usuario anónimo, deshabilitará el inicio de sesión raíz remoto y eliminará la base de datos de prueba. Este paso es un requisito básico para la seguridad de la base de datos MariaDB. (Observe que Y está en mayúscula, lo que significa que es la respuesta predeterminada).
De forma predeterminada, el paquete MaraiDB en Ubuntu usa unix_socket
para autenticar el inicio de sesión del usuario, lo que básicamente significa que puede usar el nombre de usuario y la contraseña del sistema operativo para iniciar sesión en la consola de MariaDB. Entonces puede ejecutar el siguiente comando para iniciar sesión sin proporcionar la contraseña de root de MariaDB.
sudo mariadb -u root
Para salir, ejecuta
exit;
Verifique la información de la versión del servidor MariaDB.
mariadb --version
Como puede ver, hemos instalado MariaDB 10.3.22.
mariadb Ver 15.1 Distrib 10.3.22-MariaDB, for debian-linux-gnu (x86_64) using readline 5.2
Paso 4:Instale PHP7.4
PHP7.4 está incluido en el repositorio de Ubuntu 20.04 y tiene una pequeña mejora de rendimiento con respecto a PHP7.3. Ingrese el siguiente comando para instalar PHP7.4 y algunas extensiones comunes.
sudo apt install php7.4 php7.4-fpm php7.4-mysql php-common php7.4-cli php7.4-common php7.4-json php7.4-opcache php7.4-readline php7.4-mbstring php7.4-xml php7.4-gd php7.4-curl
Las extensiones de PHP son comúnmente necesarias para los sistemas de gestión de contenido (CMS) como WordPress. Por ejemplo, si su instalación carece de php7.4-xml
, entonces algunas de las páginas de su sitio de WordPress pueden estar en blanco y puede encontrar un error en el registro de errores de Nginx como:
PHP message: PHP Fatal error: Uncaught Error: Call to undefined function xml_parser_create()
La instalación de estas extensiones de PHP garantiza que su CMS funcione sin problemas. Ahora inicie php7.4-fpm.
sudo systemctl start php7.4-fpm
Habilite el inicio automático en el momento del arranque.
sudo systemctl enable php7.4-fpm
Comprobar estado:
systemctl status php7.4-fpm
Salida de muestra:
● php7.4-fpm.service - The PHP 7.4 FastCGI Process Manager Loaded: loaded (/lib/systemd/system/php7.4-fpm.service; enabled; vendor pr> Active: active (running) since Fri 2020-04-10 14:40:26 UTC; 12s ago Docs: man:php-fpm7.4(8) Process: 21019 ExecStartPost=/usr/lib/php/php-fpm-socket-helper install /ru> Main PID: 21012 (php-fpm7.4) Status: "Processes active: 0, idle: 2, Requests: 0, slow: 0, Traffic: 0req> Tasks: 3 (limit: 9451) Memory: 9.4M CGroup: /system.slice/php7.4-fpm.service ├─21012 php-fpm: master process (/etc/php/7.4/fpm/php-fpm.conf) ├─21017 php-fpm: pool www └─21018 php-fpm: pool www
Si el comando anterior no se cierra inmediatamente después de ejecutarse. Tienes que pulsar “q ” para que se cierre.
Paso 5:Cree un bloque de servidor Nginx
Un bloque de servidor Nginx es como un host virtual en Apache. No usaremos el bloque de servidor predeterminado porque es inadecuado para ejecutar código PHP y si lo modificamos, se convierte en un desastre. Así que elimine el default
enlace simbólico en sites-enabled
directorio ejecutando el siguiente comando. (Todavía está disponible como /etc/nginx/sites-available/default
.)
sudo rm /etc/nginx/sites-enabled/default
Luego use un editor de texto de línea de comandos como Nano para crear un nuevo archivo de bloque de servidor en /etc/nginx/conf.d/ directorio.
sudo nano /etc/nginx/conf.d/default.conf
Pegue el siguiente texto en el archivo. El siguiente fragmento hará que Nginx escuche en el puerto IPv4 80 y el puerto IPv6 80 con un nombre de servidor general.
server { listen 80; listen [::]:80; server_name _; root /usr/share/nginx/html/; index index.php index.html index.htm index.nginx-debian.html; location / { try_files $uri $uri/ /index.php; } location ~ \.php$ { fastcgi_pass unix:/run/php/php7.4-fpm.sock; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; include snippets/fastcgi-php.conf; } # A long browser cache lifetime can speed up repeat visits to your page location ~* \.(jpg|jpeg|gif|png|webp|svg|woff|woff2|ttf|css|js|ico|xml)$ { access_log off; log_not_found off; expires 360d; } # disable access to hidden files location ~ /\.ht { access_log off; log_not_found off; deny all; } }
Guarde y cierre el archivo. (Para guardar un archivo en el editor de texto Nano, presione Ctrl+O
, luego presione Enter
para confirmar. Para salir, presiona Ctrl+X
.)
Luego pruebe las configuraciones de Nginx.
sudo nginx -t
Si la prueba es exitosa, vuelva a cargar Nginx.
sudo systemctl reload nginx
Paso 6:Pruebe PHP
Para probar PHP-FPM con el servidor web Nginx, necesitamos crear un info.php
archivo en el directorio webroot.
sudo nano /usr/share/nginx/html/info.php
Pegue el siguiente código PHP en el archivo.
<?php phpinfo(); ?>
Guarde y cierre el archivo. Ahora, en la barra de direcciones del navegador, ingrese server-ip-address/info.php
. Reemplazar sever-ip-address
con tu IP real. Si sigue este tutorial en su computadora local, escriba 127.0.0.1/info.php
o localhost/info.php
.
Debería ver la información de PHP de su servidor. Esto significa que los scripts PHP pueden ejecutarse correctamente con el servidor web Nginx.
¡Felicitaciones! Ha instalado con éxito Nginx, MariaDB y PHP7.4 en Ubuntu 20.04. Para la seguridad de su servidor, debe eliminar info.php
archivo ahora para evitar que un hacker lo vea.
sudo rm /usr/share/nginx/html/info.php
Consejo para solucionar problemas
Si encuentra errores, puede consultar el registro de errores de Nginx (/var/log/nginx/error.log
) para averiguar qué está mal.
Reinicio automático de Nginx
Si por algún motivo se cancela su proceso Nginx, debe ejecutar el siguiente comando para reiniciarlo.
sudo systemctl restart nginx
En lugar de escribir manualmente este comando, podemos hacer que Nginx se reinicie automáticamente editando el nginx.service
unidad de servicio systemd. Para anular la configuración predeterminada del servicio systemd, creamos un directorio separado.
sudo mkdir -p /etc/systemd/system/nginx.service.d/
Luego cree un archivo en este directorio.
sudo nano /etc/systemd/system/nginx.service.d/restart.conf
Agregue las siguientes líneas en el archivo, lo que hará que Nginx se reinicie automáticamente 5 segundos después de que se detecta una falla. El valor predeterminado de RetartSec
es 100ms , que es demasiado pequeño. Nginx puede quejarse de que "la solicitud de inicio se repite demasiado rápido" si RestartSec
no es lo suficientemente grande.
[Service] Restart=always RestartSec=5s
Guarde y cierre el archivo. Luego, vuelva a cargar systemd para que los cambios surtan efecto.
sudo systemctl daemon-reload
Para verificar si esto funcionaría, elimine Nginx con:
sudo pkill nginx
Luego verifique el estado de Nginx. Verá que Nginx se reinicia automáticamente.
systemctl status nginx
Siguiente paso
Espero que este tutorial te haya ayudado a instalar la pila LEMP en Ubuntu 20.04 LTS . Es posible que desee instalar phpMyAdmin, que es una herramienta de administración de base de datos basada en web gratuita y de código abierto.
- Cómo instalar phpMyAdmin con Nginx (LEMP) en Ubuntu 20.04 LTS
También puede instalar WordPress encima de la pila LEMP para crear su propio sitio web o blog.
- Instala WordPress en Ubuntu 20.04 con Nginx, MariaDB, PHP7.4 (LEMP)
Como siempre, si esta publicación le resultó útil, suscríbase a nuestro boletín informativo gratuito para obtener más consejos y trucos. Cuídate 🙂