Related Documents
- Firewall Settings
- firewalld
- Installing Galera
- Node Provisioning
- SELinux
- State Transfer
- wsrep Options
Other Resources
Training Video Exercises¶
Making Back-Ups with Galera Cluster¶
These exercises are part of the training video, Making Back-Ups with Galera Cluster. There are exercises related to what was taught in each section, except for the section entitled Back-Up & Restoration Plan. That particular section is in a sense another set of exercises.
Before starting these exercises, make sure you have all of the requirements and preparations in place.
Requirements & Preparation
- Test Servers: 4
- Operating System: Linux
- Open Ports: TCP 22, TCP 3306. TCP 4444, TCP & UDP 4567, TCP 4568
- Database Software: MySQL or MariaDB (vs. 10.4 or higher)
- Other Software: * Galera (Only 3)
Student Materials
Before starting an exercise, read it fully and carefully. The headings for each set of exercises before correspond to the section with the same name in training video.
Back-Up Basics
Do these exercises after viewing the first two sections of the training video: Galera Cluster Overview, and Installing Software on Nodes. Don’t configure the nodes until the next section.
- Download the sample database called,
company
from the Coderhsip site (see margin) onto one of the nodes. It’s a dump file made withmysqldump
. With MySQL or MariaDB and Galera running, use themysql
client to load the data on one node. When finished, check the other nodes to ensure they have replicated thecompany
database. Delete the dump file. - Make a directory called,
backups
, and a sub-directory in it called,temp
. Use theSET
statement to desync a different node. Execute aSHOW STATUS
statement to check that the node has a status of Desync. ExecuteSHOW VARIABLES
to determine the data directory. Next, usersync
to back-up of all of the database to thetemp
sub-directory, in thebackups
directory. When it’s finished, usetar
to create a zipped archive file (e.g.,db-backup.tgz
). Disable desync on the node. - On one of the Galera nodes, use the
DROP DATABASE
statement to drop thecompany
database. Check to see that it’s replicated on the other two nodes. Now shutdown all of the nodes. When they’ve all stopped, use the back-up file to restore the data directory on the node where it’s located. Then start that node and check if thecompany
database is back. After that, start the other two nodes. Give them a couple of minutes before checking that thecompany
database has been restored on them.
Using Standard Replication
This set of exercises require all four servers mentioned in the requirements above: three with MySQL or MariaDB, and Galera installed and running; the fourth server with only MySQL or MariaDB.
- On one of the Galera nodes, configure it also to use standard replication, to be a primary. See the link in at the top under Student Materials for an example configuration file. On the fourth server, the one without Galera Cluster, configure it to use standard replication, to be a replica to the primary. If you’re unfamiliar with standard replication, you might watch our training video on Standard Replication and Galera Cluster—or read the related article on the same topic.
- Create a user with
REPLICATION CLIENT
on the Galera node you’ve designated to be a primary. Usemysqldump
to make a copy of all of the databases on the primary. Be sure to use the--flush-logs
and--master-data
options. - Use the
scp
command to copy the dump file you created on the primary, to the replica. Load the data on the replica, using themysql
client. Execute theCHANGE MASTER TO
(MySQL < 8.4) orCHANGE REPLICATION SOURCE TO
(MySQL > 8.4) statement to provide the IP address and port 3306, as well as the replication user name and password. Then start replication by executing either theSTART SLAVE
(MySQL < 8.4) orSTART REPLICA
(MySQL > 8.4) statement on the replica. Check that replication is running fine with eitherSHOW SLAVE STATUS
(MySQL < 8.4) orSHOW REPLICA STATUS
(MySQL > 8.4, MariaDB > 10.5.1) on the replica. Try changing some data on the primary and see if it replicates to the replica. - Make a directory called
backups
, with a sub-directory within it calledtemp
. Stop the replica and use mysqldump to make a back-up on it to a thebackups
,temp
sub-directory. Copy the binary log files, as well as the MySQL configuration file to the temporary back-up sub-directory. Then tar and zip the back-up files. Start the replica again and make sure replication is running.
Using Galera Arbitrator
For the exercises in this section and the remaining sections, you won’t need the replica server. You can shut it down. You’ll only use the three servers with Galera installed on them.
- Create a configuration file for Galera Arbitrator (see link at the top under Student Materials for an example). Write a simple back-up script that will use
rsync
—or use the one linked above. Execute it usinggarbd
from the command-line. As soon as it starts, check the status of the Donor Node for comments to see if it’s desynced during the back-up. - Write another simple back-up script that will use
mysqldump
and execute it. Make sure it gives a different name to the back-up file than in the previous exercise.
Restoring Nodes and a Cluster
- Drop the
company
database on one of the nodes. Check that the deletion of the database has occurred on all of the Galera nodes and the replica. Choose one Galera node for restoration. Shutdown themysqld
daemon on the other two nodes. - Using the back-up you made with
rsync
, in the previous set of exercises, restore the data to one of the nodes. Start the other Galera nodes, one at a time. Verify that they’ve been restored. - Drop the
company
database again. This time restore the data with the dump file, using themysql
client. After a reasonable amount of time, verify that they’ve all been restored.
Note
If you’re unfamiliar with how to install Galera Cluster, watch our training video on installing Galera with MySQL, or MariaDB (see the margin for links) or read the related articles. You’ll need to configure MySQL or MariaDB and Galera Cluster and start them. There’s a link in the margin for the recommended configuration for certain sections here.
Related Documents
- Firewall Settings
- firewalld
- Installing Galera
- Node Provisioning
- SELinux
- State Transfer
- wsrep Options
Other Resources