Práctica 5. Creación de un contenedor Docker con MySQL Server
Apuntes de BD para DAW, DAM y ASIR
Curso 2025/2026
1 Creación de un contenedor Docker con MySQL Server
1.1 Requisitos
Para poder ejecutar contenedores Docker es necesario tener instalado Docker Community Edition (CE) en nuestro equipo.
En la web oficial encontrará la información necesaria para realizar la instalación de Docker CE sobre Windows, macOS, Ubuntu, Debian, Fedora y CentOS.
1.2 Cómo crear un contenedor sin persistencia de datos
Un contenedor Docker que no tiene persistencia de datos quiere decir que cuando finalice la ejecución perderá todo el contenido que hayamos creado durante la ejecución. Es decir, si durante la ejecución del contenedor hemos creado varias bases de datos en MySQL Server, éstas se perderán cuando el contenedor se detenga.
El comando que podríamos usar para lanzar nuestro contenedor Docker con MySQL Server sin persistencia de datos podría ser el siguiente:
docker run -d --rm --name mysql -e MYSQL_ROOT_PASSWORD=root -p 3306:3306 mysql:8.0docker runes el comando que nos permite crear un contenedor a partir de una imagen Docker.El parámetro
-dnos permite ejecutar el contenedor en modo detached, es decir, ejecutándose en segundo plano.El parámetro
--rmhace que cuando salgamos del contenedor, éste se elimine y no ocupe espacio en nuestro disco.El parámetro
--namenos permite asignarle un nombre a nuestro contenedor. Si no le asignamos un nombre Docker nos asignará un nombre automáticamente.El parámetro
ees para pasarle al contenedor una variable de entorno. En este caso le estamos pasando la variable de entornoMYSQL_ROOT_PASSWORDcon el valor de la contraseña que tendrá el usuariorootpara MySQL Server.El parámetro
-pnos permite mapear los puertos entre nuestra máquina local y el contenedor. En este caso, estamos mapeando el puerto3306de nuestra máquina local con el puerto3306del contenedor.mysql:8.0es el nombre de la imagen y la versión que vamos a utilizar para crear el contenedor. Si no se indica lo contrario buscará las imágenes en el repositorio oficial Docker Hub.
1.3 Cómo cambiar el plugin de autenticación en las versiones de MySQL Server superiores a la 8.0 e inferiores a la 8.4
A partir de la versión 8.0 de MySQL Server, el plugin de
autenticación que se utiliza por defecto es
caching_sha2_password, mientras que en las versiones
inferiores o iguales a la 5.7 se utiliza
mysql_native_password.
El plugin de autenticación
caching_sha2_password no está soportado por las versiones
de PHP anteriores a la 7.4, por lo tanto, si queremos conectar con MySQL
Server 8.0 desde una apliación web que utilice una versión de PHP
inferior a la 7.4, tendremos que utilizar el plugin de
autenticación mysql_native_password.
El comando que podríamos usar para lanzar nuestro contenedor Docker con MySQL Server 8.0 sin
persistencia de datos y con el plugin de autenticación
mysql_native_password podría ser el siguiente:
docker run -d --rm --name mysql -e MYSQL_ROOT_PASSWORD=root -p 3306:3306 mysql:8.0 --default-authentication-plugin=mysql_native_passwordObserve que en este caso la imagen que hemos escogido ha sido
mysql:8.0 y después del nombre de la imagen hemos utilizado
el comando:
--default-authentication-plugin=mysql_native_password
para indicar cuál será el método de autenticación que queremos utilizar.
A partir de MySQL 8.4, Oracle eliminó el soporte para el
plugin de autenticación mysql_native_password, por lo
tanto, si intenta iniciar un contenedor con este plugin en versiones
superiores o iguales a la 8.4 obtendrá un error y el contenedor no podrá
iniciarse.
MariaDB sigue soportando el plugin de autenticación
mysql_native_password en todas sus versiones, por lo tanto,
si necesita utilizar este plugin por algún motivo puede utilizar MariaDB
en lugar de MySQL Server.
docker run -d --rm --name mysql -e MYSQL_ROOT_PASSWORD=root -p 3306:3306 mariadb --default-authentication-plugin=mysql_native_password1.4 Cómo crear un contenedor con persistencia de datos
Si queremos que los datos del contenedor sean persistentes tenemos
que crear un volumen donde vamos a indicar el
directorio de nuestra máquina local vamos a almacenar el directorio
/var/lib/mysql, que es el directorio que utiliza MySQL Server para
almacenar las bases de datos.
Para crear un volumen utilizamos el parámetro -v.
Docker nos ofrece dos posibilidades para implementar persistencia de datos en los contenedores:
bind mount: pueden estar almacenados en cualquier directorio del sistema de archivos de la máquina host. Estos archivos pueden ser consultados o modificados por otros procesos de la máquina host o incluso por otros contenedores Docker.volume: se almacenan en la máquina host dentro del área del sistema de archivos que gestiona Docker. Otros procesos de la máquina host no deberían modificar estos archivos, sólo deberían ser modificados por contenedores Docker.
En la documentación oficial podemos encontrar más información sobre el uso de volumenes en Docker.
Ejemplo de uso del parámetro -v para
crear un volumen de tipo bind_mount:
-v /home/josejuan/data:/var/lib/mysql
En este caso el directorio /home/josejuan/data de
nuestra máquina local estará sincronizado con el directorio
/var/lib/mysql del contenedor con MySQL Server.
Podemos hacer uso de la variable de entorno $PWD para
indicar que queremos crear el volumen en nuestro directorio actual.
Ejemplo de uso del parámetro -v para
crear un volumen de tipo bind_mount con la variable de
entorno $PWD:
-v "$PWD":/var/lib/mysql
Ejemplo de uso del parámetro -v con un
volumen de tipo volume:
-v mysql_data:/var/lib/mysql
El comando que podríamos usar para lanzar nuestro contenedor Docker con MySQL Server con persistencia de datos en un volumen podría ser el siguiente:
docker run -d --rm --name mysql -e MYSQL_ROOT_PASSWORD=root -p 3306:3306 -v mysql_data:/var/lib/mysql mysql:8.0docker runes el comando que nos permite crear un contenedor a partir de una imagen Docker.El parámetro
-dnos permite ejecutar el contenedor en modo detached, es decir, ejecutándose en segundo plano.El parámetro
--rmhace que cuando salgamos del contenedor, éste se elimine y no ocupe espacio en nuestro disco.El parámetro
--namenos permite asignarle un nombre a nuestro contenedor. Si no le asignamos un nombre Docker nos asignará un nombre automáticamente.El parámetro
ees para pasarle al contenedor una variable de entorno. En este caso le estamos pasando la variable de entornoMYSQL_ROOT_PASSWORDcon el valor de la contraseña que tendrá el usuariorootpara MySQL Server.El parámetro
-pnos permite mapear los puertos entre nuestra máquina local y el contenedor. En este caso, estamos mapeando el puerto3306de nuestra máquina local con el puerto3306del contenedor.El parámetro
-vnos permite crear un volumen para tener persistencia de datos al finalizar el contenedor.mysql:8.0es el nombre de la imagen y la versión que vamos a utilizar para crear el contenedor. Si no se indica lo contrario buscará las imágenes en el repositorio oficial Docker Hub.
1.5 Cómo comprobar que el contenedor está en ejecución
Una vez que hemos iniciado el contenedor podemos comprobar que se está ejecutando con el siguiente comando:
docker ps
Deberíamos obtener una salida similar a esta.
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
3082ce645213 mysql:5.7.22 "docker-entrypoint.s…" 4 seconds ago Up 2 seconds 0.0.0.0:3306->3306/tcp mysql
1.6 Cómo conectar con MySQL Server
Una vez que MySQL Server está en ejecución podemos conectarnos con cualquier cliente: MySQL Workbench, PHPMyAdmin, Adminer, etc.
Los datos de conexión serán:
- Host: 127.0.0.1
- Puerto: 3306
- Usuario: root
- Password: root
1.7 Cómo detener el contenedor
Para detener el contenedor en primer lugar tenemos que conocer cuál
es su ID. Para obtenerlo podemos hacer uso del comando
docker ps.
docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
3082ce645213 mysql:8.0 "docker-entrypoint.s…" 4 seconds ago Up 2 seconds 0.0.0.0:3306->3306/tcp mysql
En la primera columna podemos ver cuál es el
CONTAINER ID. Una vez localizado el identificador
ejecutamos el comando docker stop y le pasamos como
parámetro el identificador del contenedor que queremos detener.
Para el caso anterior deberíamos ejecutar:
docker stop 3082ce645213
1.8 Ejemplo de
docker-compose.yml con MySQL Server
Docker Compose es una utilidad que nos permite gestionar varios contenedores Docker de una forma sencilla. Para ello, utiliza un archivo YAML donde se definen y configuran los servicios, los volúmenes y las redes que queremos crear.
Vamos a crear un archivo docker-compose.yml para definir
un servicio llamado mysql a partir de la imagen de MySQL
Server 8.0.
version: '3'
services:
mysql:
image: mysql:8.0
ports:
- 3306:3306
environment:
- MYSQL_ROOT_PASSWORD=root
- MYSQL_DATABASE=database
- MYSQL_USER=user
- MYSQL_PASSWORD=password
volumes:
- mysql_data:/var/lib/mysql
volumes:
mysql_data:
Puede
descargar el archivo docker-compose.yml de GitHub.
Para iniciar los servicios en segundo plano con la utilidad
docker-compose tenemos que ejecutar el siguiente
comando.
docker-compose up -dPara detener los servicios y mantener el volumen que hemos creado podemos ejecutar:
docker-compose downSi además de detener los servicios queremos eliminar el volumen que
hemos creado tenemos que añadir el parámetro -v.
docker-compose down -vPara comprobar el estado de los servicios podemos ejecutar:
docker-compose ps1.9 Referencias
- Web oficial de MySQL Server
- Imagen de Mysql Server en Docker Hub
- Web oficial de Docker
- Instalación de Docker Community Edition (CE)
- Instalación de Docker Community Edition (CE) en Windows
- Instalación de Docker Community Edition (CE) en macOS
- Instalación de Docker Community Edition (CE) en Ubuntu
- Instalación de Docker Community Edition (CE) en Debian
- Instalación de Docker Community Edition (CE) en Fedora
- Instalación de Docker Community Edition (CE) en CentOS
- Docker Hub
- Uso de volumes en Docker
- Docker Compose
- YAML
2 Licencia
Esta
página forma parte del curso
Bases de Datos de
José Juan Sánchez Hernández y
su contenido se distribuye bajo una
licencia
Creative Commons Reconocimiento-NoComercial-CompartirIgual 4.0
Internacional.