Backup and Restore of Docker Volumes: A Step-by-Step Guide
Written By Vishnu K
Last Updated: February 6, 2024
April 3, 2023

Want to receive our Blog every month?

As more and more developers turn to Docker to streamline their development processes, it becomes increasingly important to understand how to take backup and restore a volume in Docker. In this article, we’ll explore the pain areas around volume backup and restoration, the reasons for doing it, and provide a comprehensive solution that will help you take backup and restore volumes with ease.

What?

Docker has become an essential tool for many developers in recent years, allowing them to create and manage containerized applications with ease. One of the most significant advantages of Docker is its ability to manage data volumes, allowing you to store data that persists beyond the lifetime of a container.

However, even with its many benefits, Docker’s volume management can sometimes be challenging. In particular, taking backups and restoring volumes can be a complex and error-prone process. In this article, we’ll explore why you might need to take backups of your volumes and how to do it correctly.

Why?

There are many compelling reasons to do so. Here are a few reasons why you might need to take backups of your Docker volumes:

Disaster Recovery

The most obvious reason to take backups of your Docker volumes is to protect against data loss in the event of a disaster. By taking regular backups of your volumes, you can ensure that your critical data is safe and recoverable in case of an emergency.

Testing and Development

Another reason to take backups of your Docker volumes is for testing and development purposes. By creating backups of your volumes at different stages of the development process, you can easily roll back to a previous state if you encounter problems or need to test new features.

Replication

Taking backups of your Docker volumes can also be useful for replicating data across multiple environments. By creating backups of your volumes and restoring them in other environments, you can ensure that your data is consistent across all of your development, staging, and production environments.

How?

Now that we’ve explored the pain areas and reasons for taking backups and restoring volumes in Docker, let’s take a look at how to do it correctly. Here are the steps you should follow to take backups of your volumes:

Step 1: Identify the Volume

The first step in taking a backup of a volume is to identify the volume that you want to back up. You can do this by running the following command:

docker volume ls

This will show you a list of all the volumes that are currently available on your Docker host. Note down the name of the volume that you want to back up.

Step 2: Create a Backup

To create a backup of the volume, you can use the docker run command to start a container that mounts the volume you want to back up and a separate container that writes the backup data to a file.

Here’s an example of how to do this:

docker run --rm \
--mount source=<volume-name>,target=<target> \
-v $(pwd):/backup \
busybox \
tar -czvf /backup/<backup-filename>.tar.gz <target>

In this command, replace <volume-name> with the name of the volume you want to back up, <target> with the mount point inside the docker container, and <backup-filename> with a name for the backup file.

Step 3: Move the Backup File to an External Server

After you have created a backup file, it’s a good idea to move it to an external server or storage device to ensure that it’s safe and secure. Storing the backup file on a separate server or storage device can help to protect it in the event of a disaster, such as a server failure or a security breach.

To move the backup file to an external server, you can use SCP.

SCP: Secure Copy (SCP) is a secure file transfer protocol that allows you to transfer files between servers using SSH. To use SCP, you will need to have SSH access to both the source and destination servers. You can use the following command to copy the backup file to the external server:

scp /path/to/backupfile user@external-server:/path/to/destination

Step 4: Restore the Volume

If you need to restore the volume from the backup, you can use the docker run command to start a container that mounts the backup file and a separate container that writes the backup data to the volume.

Here’s an example of how to do this:

docker run --rm \
--mount source=<volume-name>,target=<target> \
-v $(pwd):/backup \
busybox \
tar -xzvf /backup/<backup-filename>.tar.gz -C /

In this command, replace <volume-name> with the name of the volume you want to back up, <target> with the mount point inside the docker container, and <backup-filename> with a name for the backup file.

Example

For the purpose of this blog, we will be setting up a basic Docker environment for MongoDB, along with an Express application to visualize the data.

Setup MongoDB Docker

Create a docker-compose.yml file.

You can use the below example to setup MongoDB docker:

# Use root/example as user/password credentials
version: '3.1'
services:
  mongo:
    image: mongo
    container_name: mongo
    restart: always
    environment:
      MONGO_INITDB_ROOT_USERNAME: root
      MONGO_INITDB_ROOT_PASSWORD: example
    volumes:
      - mongodb:/data/db
  mongo-express:
    image: mongo-express
    container_name: mongo-express
    restart: always
    ports:
      - 8081:8081
    environment:
      ME_CONFIG_MONGODB_ADMINUSERNAME: root
      ME_CONFIG_MONGODB_ADMINPASSWORD: example
      ME_CONFIG_MONGODB_URL: mongodb://root:example@mongo:27017/
volumes:
  mongodb: ~

In the above example, I added a named volume mongodb. Here we have configured docker to persist its data to a volume.

docker-compose up

To check the running docker containers you can use the below command.

docker ps

You should see 2 docker containers running i.e. mongo and mongo-express.

CONTAINER ID   IMAGE           COMMAND                  CREATED          STATUS          PORTS                                       NAMES
5f68eaf8184a   mongo-express   "tini -- /docker-ent…"   11 seconds ago   Up 9 seconds    0.0.0.0:8081->8081/tcp, :::8081->8081/tcp   mongo-express
6789cf1e7bed   mongo           "docker-entrypoint.s…"   11 seconds ago   Up 10 seconds   27017/tcp                                   mongo

You can also view the volume which you created using the following command.

docker volume ls

For me the output looks like this

DRIVER    VOLUME NAME
local     82fd19dfc5dc839a51b2afd59614474038cd0ce8b494739d883d9b503cd0c61e
local     32582d9a00557c9229418062e6308515c4c4c7eb0bb14a8c43203cafffb675c5
local     docker-test_mongodb

The volume name docker-test_mongodb was automatically created when I placed my docker-composer.yml file inside the docker-test folder. This is the location where all of our MongoDB data will be stored.

Modify MongoDB Data

To confirm that we have successfully restored the database from the volume, we need to make a minor modification to the database.

Visit 0.0.0.0:8081 where the Mongo Express is running.

Create a new database here. I created my-new-db as the new database.

So now we need to ensure that this new database that is created is also restored.

Take Backup

Let’s take the backup of the volume now.

Please run the following command to take the backup.

docker run --rm \
  --mount source=docker-test_mongodb,target=/data/db \
  -v $(pwd):/backup \
  busybox \
  tar -czvf /backup/docker-test_mongodb.tar.gz /data/db

/data/db here is the path that is mounted inside the docker container for the volume.

You should see a backup file created with docker-test_mongodb.tar.gz as the file name.

Reset Docker

As I will be performing the restore process on the same machine, I should delete both the container and the volume.

docker rm -v mongo-express
docker rm -v mongo
docker volume rm docker-test_mongodb

Restore Backup

I will proceed to recreate the containers, and we can confirm that the volume has been deleted by checking the databases on Mongo Express.

Now we can run the below command to restore the backup.

docker run --rm \
--mount source=docker-test_mongodb,target=/data/db \
-v $(pwd):/backup \
busybox \
tar -xzvf /backup/docker-test_mongodb.tar.gz -C /

Go to Mongo Express and refresh the page.

You will now be able to see that the database which we previously created has been successfully restored.

Conclusion

Taking backups and restoring volumes in Docker can be a complex and error-prone process. However, with the right approach, it’s possible to ensure that your critical data is safe and recoverable in the event of a disaster. By following the steps outlined in this article, you can take backups of your volumes with ease and restore them when necessary.

Keep up to date with Osmosys Blog!

Keep up to date with Osmosys Blog!

Keep up to date with Osmosys Blog!