Restore the backup¶
The following steps describe how to restore your backup to another Percona Server container and check whether the data is available.
-
Create another Docker volume
$ docker volume create myvol2
Expected output
myvol2
-
Run another Percona Server container to restore the backup to
Option Description --name
Provides a name to the container. If you do not use this option, Docker adds a random name. -d
Detaches the container. The container runs in the background. -e
Adds an environmental variable. This example adds the MYSQL_ROOT_PASSWORD
environment variable. The instance refuses to initialize if no environmental variable is added. Choose a more secure password, if needed.myvol2
Indicates the persistent storage for the database. 8.0.34
Use this tag to specify a specific version. You must provide at least one environment variable to access the database, such as
MYSQL_ROOT_PASSWORD
,MYSQL_DATABASE
,MYSQL_USER
, andMYSQL_PASSWORD
or the instance refuses to initialize.For this document, we are using the
8.0.34
tag. In Docker, a tag is a label assigned to an image. Tags are used to maintain different versions of an image. If we did not add a tag, Docker useslatest
as the default tag and downloads the latest image from [percona/percona-server on the Docker Hub].To use a Docker volume for persistent storage with a database, specify the path where the database stores its data inside the container, usually
/var/lib/mysql
.-
Run a Docker container example
$ docker run -d -p 3307:3306 --name psmysql2 -e MYSQL_ROOT_PASSWORD=secret -v myvol2:/var/lib/mysql percona/percona-server:8.0.34
Expected output
684464ce43d8880500f81abccb1e7440146a43f7d79c983a2a2a622b9a0d2080
-
-
Stop
psmysql2
container$ docker stop psmysql2
Expected output
psmysql2
-
Remove all created files in
myvol2
to allow xtrabackup restore data tomyvol2
The
--rm
option automatically removes the temporary container created from percona/percona-xtrabackup:8.0.34 image after the container exits.$ docker run --volumes-from psmysql2 -v backupvol:/backup_8034 -it --rm --user root percona/percona-xtrabackup:8.0.34 /bin/bash -c "rm -rf /var/lib/mysql/*"
If the command executes successfully, the expected output is empty.
-
Restore backup of
psmysql
frombackupvol
to a newpsmysql2
instance.$ docker run --volumes-from psmysql2 -v backupvol:/backup_8034 -it --rm --user root percona/percona-xtrabackup:8.0.34 /bin/bash -c "xtrabackup --copy-back --datadir=/var/lib/mysql/ --target-dir=/backup_8034"
Expected output
2023-12-14T16:06:39.845762-00:00 0 [Note] [MY-011825] [Xtrabackup] recognized server arguments: --datadir=/var/lib/mysql/ 2023-12-14T16:06:39.848408-00:00 0 [Note] [MY-011825] [Xtrabackup] recognized client arguments: --copy-back=1 --target-dir=/backup_8034 xtrabackup version 8.0.34-29 based on MySQL server 8.0.34 Linux (x86_64) (revision id: 5ba706ee) 2023-12-14T16:06:39.849053-00:00 0 [Note] [MY-011825] [Xtrabackup] cd to /backup_8034/ ... 2023-12-14T16:06:40.111577-00:00 1 [Note] [MY-011825] [Xtrabackup] Creating directory ./#innodb_redo 2023-12-14T16:06:40.111603-00:00 1 [Note] [MY-011825] [Xtrabackup] Done: creating directory ./#innodb_redo 2023-12-14T16:06:40.111634-00:00 1 [Note] [MY-011825] [Xtrabackup] Copying ./ibtmp1 to /var/lib/mysql/ibtmp1 2023-12-14T16:06:40.125971-00:00 1 [Note] [MY-011825] [Xtrabackup] Done: Copying ./ibtmp1 to /var/lib/mysql/ibtmp1 2023-12-14T16:06:40.144298-00:00 0 [Note] [MY-011825] [Xtrabackup] completed OK!
This command restores the backup files from the
backup_8034
volume to thepsmysql2
container. It uses thepercona/percona-xtrabackup:8.0.34
image to run a temporary container with root privileges. It executes the xtrabackup tool with the--copy-back
option, which copies the files from thebackup_8034
volume to the /var/lib/mysql/
directory in thepsmysql2
container. The command uses –rm option to delete the temporary container after it exits.
Validate the backup¶
This section describes the backup validation steps assuming that you backed up mydb
database with the employees
table as we have in our example. The validation steps may vary depending on your data set.
-
Change the owner of the files in
myvol2
fromroot
tomysql
To avoid permission issues when running
psmysql2
container, you need to change the owner because the files were restored byroot
user andpsmysql2
will usemysql
user.$ docker run --volumes-from psmysql2 -v backupvol:/backup_8034 -it --rm --user root percona/percona-xtrabackup:8.0.34 /bin/bash -c "chown -R mysql:mysql /var/lib/mysql/"
If the command executes successfully, the expected output is empty.
-
Start the
psmysql2
container$ docker start psmysql2
Expected output
psmysql2
-
Connect to the database instance.
For this example, we have the following options:
Option Description it
Interact with the container and be a pseudo-terminal psmysql2
Running container name mysql
Connects to a database instance -u
Specifies the user account used to connect -p
Use this password when connecting -
Connect to the database instance example
$ docker exec -it psmysql2 mysql -uroot -p
You are prompted to enter the password, which is
secret
.Enter password:
You should see the following result.
Expected output
Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 31 Server version: 8.0.34-26 Percona Server (GPL), Release 26, Revision 0fe62c85 Copyright (c) 2009-2023 Percona LLC and/or its affiliates Copyright (c) 2000, 2023, Oracle and/or its affiliates. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
-
-
Check the list of databases to make sure, the backed up,
mydb
database is in the list.mysql> show databases;
Expected output
+--------------------+ | Database | +--------------------+ | information_schema | | mydb | | mysql | | performance_schema | | sys | +--------------------+ 5 rows in set (0.03 sec)
-
Use the
mydb
database.mysql> use mydb;
Expected output
Database changed
-
Check that your table contains data
mysql> SELECT * FROM employees;
Expected output
+----+--------------------+-----------------------------------+-------------+ | id | name | email | country | +----+--------------------+-----------------------------------+-------------+ | 1 | Erasmus Richardson | posuere.cubilia.curae@outlook.net | England | | 2 | Jenna French | rhoncus.donec@hotmail.couk | Canada | | 3 | Alfred Dejesus | interdum@aol.org | Austria | | 4 | Hamilton Puckett | dapibus.quam@outlook.com | Canada | | 5 | Michal Brzezinski | magna@icloud.pl | Poland | | 6 | Zofia Lis | zofial00@hotmail.pl | Poland | | 7 | Aisha Yakubu | ayakubu80@outlook.com | Nigeria | | 8 | Miguel Cardenas | euismod@yahoo.com | Peru | | 9 | Luke Jansen | nibh@hotmail.edu | Netherlands | | 10 | Roger Pettersen | nunc@protonmail.no | Norway | +----+--------------------+-----------------------------------+-------------+ 10 rows in set (0.00 sec)