Day 19 Task: Docker for DevOps Engineers

Day 19 Task: Docker for DevOps Engineers

Facilitating Data Management: Understanding Docker Volumes and Networks

ยท

3 min read

๐Ÿ”ถ Docker-Volume

Docker allows you to create something called volumes. Volumes are like separate storage areas that can be accessed by containers. They allow you to store data, like a database, outside the container, so it doesn't get deleted when the container is deleted. You can also mount from the same volume and create more containers having the same data. reference

Docker volume

๐Ÿ”ถ Docker Network

Docker allows you to create virtual spaces called networks, where you can connect multiple containers (small packages that hold all the necessary files for a specific application to run). This way, the containers can communicate with each other and with the host machine (the computer on which the Docker is installed). When we run a container, it has its own storage space that is only accessible by that specific container. If we want to share that storage space with other containers, we can't do that. reference

๐Ÿ”ถ Task-1: multi-container docker-compose file

  • Create a multi-container docker-compose file that will bring UP and bring DOWN containers in a single shot ( Example - Create application and database container )

  • git clone from

Use the docker-compose up command with the -d flag to start a multi-container application in detached mode.

#To start the multi-container
docker-compose up -d

Use the docker-compose ps command to view the status of all containers, and docker-compose logs to view the logs of a specific service.

#To view the status
docker-compose ps

Use the docker-compose down command to stop and remove all containers, networks, and volumes associated with the application

#To stop the container
docker-compose down

๐Ÿ”ถ Task-2: Docker Volumes

  • Learn how to use Docker Volumes and Named Volumes to share files and directories between multiple containers.
#To create docker volume
docker volume create --name django_todo_volume --opt type=none --opt device=/home/ubuntu/Docker_Practice/task/Day19/volumes/django-app-volume --opt o=bind

  • Create two or more containers that read and write data to the same volume using the docker run --mount command.
#mount
docker run -d --mount source=django_todo_volume,target=/data -p 8000:8000 django_todo_web:latest

  • Verify that the data is the same in all containers by using the docker exec command to run commands inside each container.
#Docker exec -it <container-id> bash
docker exec -it 23e4f8de944c bash

  • Use the docker volume ls command to list all volumes and the docker volume rm command to remove the volume when you're done.

In conclusion, Docker volumes play a crucial role in managing data persistence and sharing between containers, especially in multi-container and multi-stage setups. Volumes provide a mechanism to decouple data storage from the container lifecycle, ensuring data integrity, scalability, and easy container management.

For multi-container applications orchestrated with tools like Docker Compose, volumes enable seamless data sharing between different services, allowing them to collaborate without the constraints of container boundaries. This promotes modularization, enhances security, and simplifies data management.

Stay in the loop with my latest insights and articles on cloud โ˜๏ธ and DevOps โ™พ๏ธ by following me on Hashnode, LinkedIn (https://www.linkedin.com/in/chandreshpatle28/), and GitHub (https://github.com/Chandreshpatle28).

Thank you for reading! Your support means the world to me. Let's keep learning, growing, and making a positive impact in the tech world together.

#Git #Linux Devops #Devopscommunity #90daysofdevopschallenge #python #docker

Did you find this article valuable?

Support Chandresh Patle's Blog by becoming a sponsor. Any amount is appreciated!

ย