Cómo instalar Drupal con LAMP (Apache MySQL PHP) en Ubuntu 20.04 LTS

1 mar 2021 6 min di lettura
Cómo instalar Drupal con LAMP (Apache MySQL PHP) en Ubuntu 20.04 LTS
Indice dei contenuti

Introducción

Drupal es un marco de gestión de contenido web gratuito y de código abierto escrito en PHP y distribuido bajo la Licencia Pública General GNU. Drupal proporciona un marco de back-end para al menos el 2,3% de todos los sitios web del mundo, desde blogs personales hasta sitios corporativos, políticos y gubernamentales.

LAMP es un grupo de software de código abierto que normalmente se instala junto para permitir que un servidor aloje sitios web y aplicaciones web dinámicos. LAMP incluye Apache, MySQL, PHP.

En este tutorial instalaremos LAMP con Drupal en Ubuntu 20.04 LTS Focal Fossa.

Si desea instalar Drupal en un servidor remoto, continúe leyendo, de lo contrario, omita el primer párrafo "Conectando al servidor" y lea el siguiente.

Conexión al servidor

Para acceder al servidor, necesita conocer la dirección IP. También necesitará su nombre de usuario y contraseña para la autenticación. Para conectarse al servidor como root, escriba el siguiente comando:

ssh root@IP_DEL_SERVER

A continuación, deberá ingresar la contraseña del usuario root.

Si no está utilizando el usuario root, puede iniciar sesión con otro nombre de usuario utilizando el mismo comando, luego cambie root a su nombre de usuario:

ssh nome_utente@IP_DEL_SERVER

Luego se le pedirá que ingrese su contraseña de usuario.

El puerto estándar para conectarse a través de ssh es 22, si su servidor usa un puerto diferente, deberá especificarlo usando el parámetro -p, luego escriba el siguiente comando:

ssh nome_utente@IP_DEL_SERVER -p PORTA

Ahora está conectado a su servidor, está listo para comenzar a instalar Drupal en Ubuntu 20.04 LTS.

Instalar Apache

Los repositorios de paquetes oficiales de Ubuntu incluyen una versión actualizada de Apache, luego podemos instalar los paquetes necesarios usando apt.

Actualice la lista de paquetes de Ubuntu para tener la última versión de las listas de repositorios, desde la terminal:

sudo apt update

Para instalar Apache, abra la terminal y emita estos comandos:

sudo apt install apache2

Si el firewall de Ubuntu está activo, debe habilitar el tráfico para Apache:

sudo ufw allow in "Apache Full"

En este punto, el servidor está listo con las configuraciones predeterminadas. Simplemente conéctese a su dirección IP pública o localhost:

http://localhost

Para reiniciar Apache:

sudo service apache2 restart

Para detener Apache:

sudo service apache2 stop

Para iniciar Apache:

sudo service apache2 start

Configurar un host virtual

Cuando se utiliza el servidor web Apache, los hosts virtuales se pueden utilizar para alojar varios dominios y luego varios sitios web en un solo servidor. Configuraremos un dominio llamado example.com, pero debería usar un dominio existente.

Apache en Ubuntu 20.04 LTS tiene un bloque de servidor habilitado de forma predeterminada que está configurado para servir documentos desde el /var/www/html para un solo sitio. Si aloja varios sitios, en lugar de modificar /var/www/html, cree una estructura de directorio dentro de /var/www dejando /var/www/html como el directorio predeterminado para servir si la solicitud de un cliente no coincide con ningún otro sitio configurado como un anfitrión virtual.

Cree el directorio para esempio.com, usando la -p para crear todos los directorios necesarios:

sudo mkdir -p /var/www/drupal/

Asigne al usuario actual como propietario del nuevo directorio:

sudo chown -R $USER:$USER /var/www/drupal

Asegúrese de que los permisos sean correctos:

sudo chmod -R 755 /var/www/drupal

Cree un nuevo archivo de configuración para el esempio.com, sin cambiar el predeterminado:

sudo nano /etc/apache2/sites-available/drupal.conf

Pegue las siguientes líneas de código, asegurándose de cambiar los valores de su dominio, en este caso esempio.com:


<VirtualHost *:80>
 ServerAdmin [email protected]
 ServerName esempio.com
 ServerAlias www.esempio.com
 DocumentRoot /var/www/drupal
 ErrorLog ${APACHE_LOG_DIR}/error.log
 CustomLog ${APACHE_LOG_DIR}/access.log combined
 <Directory /var/www/drupal>
 AllowOverride All
 Order allow,deny
 Allow from all
 </Directory>
 </VirtualHost>

Guarde y cierre el archivo.

Habilite el nuevo sitio:

sudo a2ensite drupal.conf

Verifique si los datos ingresados en los archivos son correctos:

sudo apache2ctl configtest

Debería ver una respuesta similar a esta:


Syntax OK

Reinicie Apache:

sudo systemctl restart apache2

Ahora puede conectarse al host virtual que acaba de crear conectándose a su dominio:


http://esempio.com

Instalar MySQL

Puede instalar MySQL usando el repositorio oficial de Ubuntu con apt. Instale MySQL:

sudo apt install mysql-server

Asegurar MySQL

Inicie un script MySQL para cambiar algunas configuraciones:

sudo mysql_secure_installation

Se le pedirá que ingrese una contraseña para el usuario root, que utilizará para iniciar sesión en el servidor MySQL.

Ingrese "y" para "sí" o cualquier otra letra para "no".

Se le preguntará si desea probar la seguridad de la contraseña.

Entonces se recomienda presionar "y" y luego "sí".

  • Eliminar usuarios anónimos
  • Deshabilitar el inicio de sesión de root de forma remota
  • Eliminar la base de datos de prueba
  • Actualizar las nuevas reglas

Cambiar el método de autenticación

A partir de la versión 5.7 de MySQL, el usuario root de MySQL está configurado para autenticarse a través del complemento auth_socket de forma predeterminada en lugar de una contraseña.

Para usar una contraseña para conectarse a MySQL como usuario root, necesita cambiar el método de autenticación, de auth_socket a mysql_native_password.

Como aún no se ha establecido una contraseña, puede conectarse al servidor MySQL simplemente usando el comando mysql o sudo mysql si ha iniciado sesión como usuario normal. A continuación, deberá utilizar el comando mysql -u root -p como root, de lo contrario sudo mysql -u root -p como usuario normal.

Entonces, si ha iniciado sesión como root, escriba en la terminal:

mysql

De lo contrario, si ha iniciado sesión como un usuario normal con privilegios de sudo:

sudo mysql

Para verificar el método de autenticación asociado con las cuentas mysql:

SELECT user,authentication_string,plugin,host FROM mysql.user;

Debería recibir un mensaje similar a este:

+------------------+------------------------------------------------------------------------+-----------------------+-----------+
 | user | authentication_string | plugin | host |
 +------------------+------------------------------------------------------------------------+-----------------------+-----------+
 | debian-sys-maint | $A$005$_I4jtC|i.)h^*f*z`:2qYuy4CAHnLW21jE8.omOKjDIEFVcepe6eQO/T8QS61 | caching_sha2_password | localhost |
 | mysql.infoschema | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED | caching_sha2_password | localhost |
 | mysql.session | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED | caching_sha2_password | localhost |
 | mysql.sys | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED | caching_sha2_password | localhost |
 | root | | auth_socket | localhost |
 +------------------+------------------------------------------------------------------------+-----------------------+-----------+
 5 rows in set (0.00 sec)

Como puede ver, el método de autenticación auth_socket está configurado por defecto para el usuario root.

Para utilizar la autenticación de contraseña para la cuenta raíz, realice los siguientes cambios:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'TUA_PASSWORD';
Atención:Your password does not satisfy the current policy requirements.este tutorial

Ahora puede verificar el nuevo método de autenticación asociado con el usuario raíz:

SELECT user,authentication_string,plugin,host FROM mysql.user;

Debería recibir un mensaje similar a este:

+------------------+------------------------------------------------------------------------+-----------------------+-----------+
 | user | authentication_string | plugin | host |
 +------------------+------------------------------------------------------------------------+-----------------------+-----------+
 | debian-sys-maint | $A$005$_I4jtC|i.)h^*f*z`:2qYuy4CAHnLW21jE8.omOKjDIEFVcepe6eQO/T8QS61 | caching_sha2_password | localhost |
 | mysql.infoschema | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED | caching_sha2_password | localhost |
 | mysql.session | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED | caching_sha2_password | localhost |
 | mysql.sys | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED | caching_sha2_password | localhost |
 | root | *13097EDBBF2AB852D55D47ED1477E2901F60DFE1 | mysql_native_password | localhost |
 +------------------+------------------------------------------------------------------------+-----------------------+-----------+
 5 rows in set (0.00 sec)

Salga del indicador de MySQL:

exit;

Para iniciar sesión nuevamente en el servidor MySQL ahora, deberá ingresar una contraseña, luego desde la terminal:

Si ha iniciado sesión como root, escriba en la terminal:

mysql -u root -p

De lo contrario, si ha iniciado sesión como un usuario normal con privilegios de sudo:

sudo mysql -u root -p

Crea una base de datos para Drupal:

CREATE DATABASE drupal DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;

Asocie un nuevo usuario a la base de datos drupal con contraseña y privilegios:

CREATE USER 'drupalsuser'@'localhost' IDENTIFIED WITH mysql_native_password BY 'tua_password';
GRANT ALL PRIVILEGES ON drupal.* TO 'drupalsuser'@'localhost';
Atención:Your password does not satisfy the current policy requirements.este tutorial

Actualizar privilegios:

FLUSH PRIVILEGES;

Salir de mysql:

exit;

Instalar PHP

Para instalar PHP y extensiones útiles para Drupal, desde la terminal:

sudo apt install php php-cli libapache2-mod-php php-mysql php-curl php-gd php-mbstring php-xml php-xmlrpc php-soap php-intl php-zip

Reinicie Apache:

sudo service apache2 restart

Instalar Drupal

Da los siguientes comandos desde la terminal, ingresa a la carpeta Drupal:

cd /var/www/drupal

Descarga Drupal, actualmente la última versión es 8.8.5:

sudo wget https://ftp.drupal.org/files/projects/drupal-8.8.5.zip

Instale Zip y Unzip para administrar archivos.zip:

sudo apt-get install zip unzip

Extracto de drupal:

sudo unzip drupal-8.8.5.zip

Ingrese a la nueva carpeta:

cd drupal-8.8.5

Mueva todos los archivos a la carpeta raíz:

sudo mv * /var/www/drupal
mv.htaccess /var/www/drupal

Sube un nivel:

cd..

Elimina la carpeta creada para extraer los archivos, ahora vacía:

sudo rm -rf drupal-8.8.5

Habilitar mod_rewrite:

sudo a2enmod rewrite

Reinicie Apache:

sudo service apache2 restart

Cambiar permisos:

sudo chown -R www-data:www-data /var/www/

Conéctese a su nombre de dominio:


http://esempio.com

Debería ver la primera pantalla de instalación de Drupal.

El servidor está listo para instalar Drupal con LAMP, Virtual Host, PHP, MySQL en Ubuntu 20.04 LTS Focal Fossa.

Después de conectarse a su dirección web e instalar Drupal, ingrese al siguiente directorio:

cd /var/www/drupal/sites/default

Por razones de seguridad, abra el archivo settings.php:

sudo nano settings.php

Agregue estas líneas al final del archivo usando su nombre de dominio:

$settings['trusted_host_patterns'] = [
 '^esempio\.com$',
 '^www\.esempio\.com$',
 ];

Guarde y cierre el archivo.

Conclusión

En este tutorial hemos visto cómo instalar Drupal con LAMP en Ubuntu 20.04 LTS Focal Fossa.

Support us with a

Successivamente, completa il checkout per l'accesso completo a Noviello.it.
Bentornato! Accesso eseguito correttamente.
Ti sei abbonato con successo a Noviello.it.
Successo! Il tuo account è completamente attivato, ora hai accesso a tutti i contenuti.
Operazione riuscita. Le tue informazioni di fatturazione sono state aggiornate.
La tua fatturazione non è stata aggiornata.