Table of Contents
Introduction
Docker Volume: In this guide, we about see how to attach a persistent volume in a docker container. If we don’t have separate storage the data will not persist once the container is no longer up and running. To eliminate the ephemeral state of filesystem we need to use anyone of volume.
For demonstration purpose we are going to use with an MYSQL container its data will be saved under /var/lib/mysql inside the docker container, so our volume should be bind-mounted under the same location from our docker host to the container with required proper SELinux contexts.
Articles related to Docker Series
- How to install Docker on Red Hat Enterprise Linux and CentOS Linux 7
- Search for Docker images and launch a container
- Connect to Docker containers and expose the network
- How to manage Docker containers
- Managing Docker data persistently by attaching a volume
Step 1: Label with SELinux context for docker volume
In the latest version of RHEL/CentOS flavour, you can check for SELinux content by following below SELinux guide.
Create a directory to save the data of the container and it should be labelled with “svirt_sandbox_file_t” Moreover it needs to be owned by user and group 27:27 recursively.
# mkdir /mysql_container # chown -R 27:27 /mysql_container # chcon -t svirt_sandbox_file_t /mysql_container
data:image/s3,"s3://crabby-images/88cc7/88cc7fd481305c7b88f3f70b032dc04d857d0b6c" alt="How to attach a Docker volume to the container 2 Manage data in Docker container"
Step 2: Mounting a Volume
Let’s download the MySQL docker image to launch a docker container
# docker pull mysql
To know about the available Environment Variables of MYSQL container image navigate to
Click Here to know the MySQL containers environment variables from Docker Hub
We are using with only three of environment variables for now.
MYSQL_ROOT_USER MYSQL_ROOT_PASSWORD MYSQL_DATABASE
Launch a container from MySQL image in detaches mode in the name of “mysql-pro-dbsrv” by mounting volume from source to destination using the “-v” option. By following we can assign to a number of variables which going to be used inside the container. To assign variables to use with “-e” the option.
# docker run --name mysql-pro-dbsrv -d -v /mysql_container:/var/lib/mysql/ -e MYSQL_ROOT_USER=root -e MYSQL_ROOT_PASSWORD=password123 mysql # docker ps
data:image/s3,"s3://crabby-images/c70c4/c70c487eb8d5bf5d766ac00ffcd15c44cb639f56" alt="How to attach a Docker volume to the container 3 Launch a container by attaching a volume"
- –name Name of the container
- -d Launching container in detach mode
- -v Bind mount a volume
- -e Set environment variables
In case, if you have already started the container and not included any environment variable the container will be in error state. By running log option on the container we will get to know the available variables as well.
Step 3: Verifying environment variable and MYSQL DB
Once container up and running access its shell to verify DB files.
# docker exec -it mysql-pro-dbsrv /bin/bash # ls -lthr /var/lib/mysql/
data:image/s3,"s3://crabby-images/1755e/1755e0998b760c5267df50b0151591c76487e833" alt="How to attach a Docker volume to the container 4 List the MySQL file inside the container"
List the Environment variables and do a grep
# env | grep MYSQL
data:image/s3,"s3://crabby-images/944be/944bee9bbd1059fffa14e7bc6d77a7865b29de96" alt="How to attach a Docker volume to the container 5 Finding the assigned env variable in a container"
Login to MYSQL Database with assigned environmental variables.
# mysql -u root -p # exit
data:image/s3,"s3://crabby-images/1b626/1b6269853b09e3486936ff5e36a4dd1b0898dd4e" alt="How to attach a Docker volume to the container 6 Verify MySQL login in Container"
Now, let us check MYSQL related files from docker host. The database files are saved under below location which mounted inside a Docker container.
# ls -lthr /mysql_container/
data:image/s3,"s3://crabby-images/5bad4/5bad41eed1ea7036d479b85f0bdc9874a13a5b8a" alt="How to attach a Docker volume to the container 7 List the MySQL files in bind mount locally from the Docker host"
Step 4: Removing MYSQL container and data
To remove a Docker volume or persistent storage, we need to follow the above steps in reverse order.
But before starting with removing first we need to stop the container, and then remove the container, by following remove all files from bind source and finally remove the MySQL image.
# docker stop mysql-pro-dbsrv # docker rm mysql-pro-dbsrv # rm -rfv /var/local/mysql # docker rmi mysql
data:image/s3,"s3://crabby-images/d4136/d4136f3d69589aa798e1fc0c724f28d4dac543c8" alt="How to attach a Docker volume to the container 8 Removing docker container and bind volume"
That’s it we have completed with mounting a volume to save data persistently in Docker containers.
Conclusion
In this short article, we have seen how to save Docker data persistently by attaching a docker volume. By following let us cover with more docker topics till then subscribe with the newsletter to keep updated.