Cómo instalar y configurar MySQL en Ubuntu

METROySQL es uno de los sistemas de administración de bases de datos relacionales de código abierto (RDBMS) más comunes, basado en el lenguaje de consulta estructurado (SQL), que es un lenguaje de programación utilizado para administrar los datos almacenados en una base de datos.

Es rápido, sencillo de usar incluso para los principiantes que ingresan al desarrollo de backend y se integra en varios paquetes de pila como Xampp, Lampp y Wamp.

En esta publicación en particular, le mostraremos cómo instalar el servidor MySQL en su sistema Ubuntu. La información adicional incluye la configuración de las opciones de seguridad, el ajuste de los métodos de autenticación y la creación de un nuevo usuario. Nuestra versión de Ubuntu preferida en este tutorial es Ubuntu 20.04 LTS, que es la última versión al momento de escribir este artículo.

Índice

Instalación de MySQL en Ubuntu

Requisitos

Necesitará tener privilegios elevados (root) en su sistema. Puede hacerlo ejecutando el siguiente comando.

sudo su

Procedimiento

Al momento de escribir esta publicación, la versión actual de MySQL Linux es la versión 5.7. Para comenzar con la instalación, siga los pasos a continuación:

Paso 1) Asegúrese de que todos los paquetes y repositorios de su sistema estén actualizados. Puede hacerlo ejecutando el siguiente comando:

sudo apt update

Actualice los paquetes de su sistema
Actualice los paquetes de su sistema

Paso 2) Ahora, instalaremos MySQL a través del administrador de paquetes apt. Ejecute el siguiente comando.

sudo apt install mysql-server

Instalación de MySQL Server
Instalación de MySQL Server

Paso 3) Después de una instalación exitosa, mysql-service debería iniciarse automáticamente. Puede confirmarlo ejecutando el siguiente comando:

sudo systemctl status mysql

Debería obtener un resultado similar al de la imagen a continuación.

Estado de MySQL
Estado de MySQL

En cualquier caso que el servicio no se esté ejecutando, ejecute el siguiente comando:

sudo /etc/init.d/mysql start

Verificar la instalación de MySQL (opcional)

Puede verificar su instalación ejecutando el comando a continuación, que generará la versión y distribución de MySQL instaladas en su sistema.

mysql --version

Distribución de versiones de MySQL
Distribución de versiones de MySQL

Asegure su servidor MySQL

Ahora que el servidor MySQL se instaló correctamente, debe establecer algunos parámetros para garantizar la seguridad del servidor y las bases de datos que configure en el futuro.

En otros casos, una vez completada la instalación del paquete del servidor MySQL, la utilidad mysql-secure-installation se iniciará automáticamente. Sin embargo, si este no es su caso, ejecute el siguiente comando:

sudo mysql_secure_installation

Verá un mensaje que le preguntará si debe VALIDAR EL PLUGIN DE CONTRASEÑA. Mejora la seguridad del servidor MySQL al verificar la solidez de las contraseñas de usuario, lo que permite a los usuarios establecer solo contraseñas seguras. Presione Y para aceptar VALIDACIÓN o la tecla RETORNO para omitir.

Aceptar el complemento de validación de contraseña
Aceptar el complemento de validación de contraseña

A continuación, debería ver un mensaje para establecer la contraseña de root. Ingrese su contraseña y presione enter. Tenga en cuenta que, por razones de seguridad, no se muestra lo que escriba en la consola.

Ingrese la contraseña de root de MySQL
Ingrese la contraseña de root de MySQL

A continuación, debería ver un mensaje que le preguntará si desea eliminar todos los usuarios anónimos, ingrese Y para SÍ. Para cualquier otro mensaje desde aquí, ingrese Y para YES.

Eliminar usuarios anónimos
Eliminar usuarios anónimos

Inicie sesión como root y ajuste la autenticación de usuario

El servidor MySQL viene con una utilidad del lado del cliente que le permite acceder e interactuar con la base de datos desde la Terminal de Linux.

Por lo general, después de una nueva instalación de MySQL en Ubuntu sin realizar ninguna configuración, los usuarios que acceden al servidor se autentican mediante el complemento de socket de autenticación (auth_socket).

El uso de auth_socket impide que el servidor autentique a un usuario mediante una contraseña. No solo plantea problemas de seguridad, sino que también impide que los usuarios accedan a la base de datos mediante programas externos como phpMyAdmin. Necesitamos cambiar el método de autenticación de auth_socket al uso de mysql_native_password.

Para hacer esto, necesitaremos abrir la consola MySQL. Ejecute el siguiente comando en la terminal de Linux.

sudo mysql

Consola MySQL
Consola

Ahora, debemos verificar el método de autenticación utilizado por la base de datos en diferentes usuarios. Puede hacerlo ejecutando el siguiente comando.

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

Verifique los métodos de autenticación de usuarios
Verifique los métodos de autenticación de usuarios

De la imagen de arriba, podemos confirmar que el usuario root está autenticado usando el complemento auth_socket. Necesitamos cambiar al uso de 'autenticación de contraseña' usando el comando 'ALTER USER' a continuación. Asegúrese de usar una contraseña segura (debe tener más de ocho caracteres que combinen números, cadenas y símbolos especiales), ya que reemplazará la contraseña que estableció al ejecutar el comando 'sudo mysql_secure_installation' anterior. Ejecute el siguiente comando.

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_password';

Cambiar la autenticación raíz
Cambiar la autenticación raíz

Tenga en cuenta que el texto resaltado en la imagen de arriba es donde ingresará su contraseña segura. Colóquelo entre etiquetas individuales. Ahora, necesitamos recargar las tablas de subvenciones y actualizar los cambios en el servidor MySQL. Haga esto ejecutando el siguiente comando.

FLUSH PRIVILEGES;

Privilegios de descarga
Privilegios de descarga

Una vez hecho esto, debemos confirmar que el uso de root ya no usa auth_socket para la autenticación. Hágalo ejecutando el siguiente comando nuevamente.

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

Verifique la autenticación raíz
Verifique la autenticación raíz

En la imagen de arriba, vemos que el método de autenticación de root ha cambiado de 'auth_socket' a 'contraseña'.

Dado que hemos cambiado el método de autenticación para root, no podemos usar el mismo comando que usamos antes para abrir la consola MySQL. Es decir, 'sudo mysql'. Necesitaremos incluir los parámetros de nombre de usuario y contraseña, como se muestra a continuación.

mysql -u root -p

La '-u' indica el usuario, que es 'root' para nuestro caso y '-p' significa 'contraseña', que el servidor le pedirá que ingrese una vez que presione la tecla Enter.

mysql -u -p
mysql -u -p

Creando un nuevo usuario

Una vez que todo esté configurado, puede crear un nuevo usuario al que otorgará los privilegios adecuados. En nuestro caso aquí, crearemos un usuario 'tuts_fosslinux' y asignaremos derechos sobre todas las tablas de la base de datos y permisos para cambiar, eliminar y agregar privilegios de usuario. Ejecute los comandos debajo de línea por línea.

CREATE USER 'tuts_fosslinux'@'localhost' IDENTIFIED BY 'strong_password';

GRANT ALL PRIVILEGES ON *.* TO 'tuts_fosslinux'@'localhost' WITH GRANT OPTION;

El primer comando creará el nuevo usuario y el segundo asigna los privilegios necesarios.

Crea un nuevo usuario y concede permisos
Crea un nuevo usuario y concede permisos

Ahora podemos probar nuestro nuevo usuario ejecutando el siguiente comando.

mysql -u tuts_fosslinux -p

Prueba nuestro nuevo usuario
Prueba nuestro nuevo usuario

Instale MySQL-Server en el servidor Ubuntu

La instalación del servidor MySQL en el servidor Ubuntu no es muy diferente de los pasos descritos anteriormente. Sin embargo, dado que se accede a un servidor de forma remota, también necesitamos habilitar el acceso remoto para nuestro servidor.

Para instalar la base de datos y configurar las opciones de seguridad, simplemente ejecute los siguientes comandos línea por línea en la Terminal.

sudo apt update
sudo apt install mysql-server
sudo mysql_secure_installation

Después de una instalación exitosa, necesitaremos habilitar el acceso remoto. Lógicamente, todo lo que tenemos que hacer es abrir un puerto en el firewall del servidor de Ubuntu para que el servidor MySQL se comunique. De forma predeterminada, el servicio MySQL se ejecuta en el puerto 3306. Ejecute los siguientes comandos.

sudo ufw enable
sudo ufw allow mysql

Habilitar el acceso remoto
Habilitar el acceso remoto

Para mejorar la confiabilidad y accesibilidad de nuestras bases de datos MySQL, podemos configurar el servicio del servidor MySQL para que comience a ejecutarse en el arranque. Para hacerlo, ejecute el siguiente comando.

sudo systemctl enable mysql

Habilitar el servicio mysql en el arranque
Habilitar el servicio MySQL en el arranque

Ahora necesitaremos configurar las interfaces de nuestro servidor. Permitirá que el servidor escuche interfaces accesibles de forma remota. Tendremos que editar el archivo 'mysqld.cnf'. Ejecute los siguientes comandos.

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

Configurar la dirección de enlace
Configurar la dirección de enlace

De forma predeterminada, la dirección de enlace es '127.0.0.1'. Agregue la dirección de enlace para su interfaz de red pública y otra para la interfaz de red de servicio. Puede configurar su dirección de enlace como '0.0.0.0' para todas las direcciones IP.

Conclusión

Espero que haya disfrutado de este tutorial sobre cómo configurar el servidor MySQL en su sistema Ubuntu. Si recién está comenzando con MySQL y todo lo que necesita es crear una base de datos y un usuario simples, los pasos dados anteriormente deberían ser de gran ayuda. Si encuentra este artículo ingenioso, no dude en compartir el enlace con un amigo.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Subir