GNU/Linux >> Tutoriales Linux >  >> Ubuntu

Cómo instalar LEMP Stack en servidor/escritorio Ubuntu 20.04

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.1localhost 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.phplocalhost/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 🙂


Ubuntu
  1. Cómo instalar Nginx en Ubuntu 20.04

  2. Cómo instalar Ubuntu Desktop desde Ubuntu Server

  3. Cómo instalar la pila LEMP en Ubuntu 20.04

  4. Cómo instalar LEMP Stack en Debian 10 Buster Server/Desktop

  5. Cómo instalar LEMP en Ubuntu 16.04

Cómo instalar LAMP Stack en servidor/escritorio Ubuntu 20.04

Cómo instalar Nginx en Ubuntu

Cómo instalar LEMP en Ubuntu 15.10

Cómo instalar LEMP en Ubuntu 16.04

Cómo instalar Nginx en Ubuntu 18.04 LTS

Cómo instalar LEMP Stack con PhpMyAdmin en Ubuntu 20.04