Skip to content

For help, click the link below to get free database assistance or contact our experts for personalized support.

Backup example

This example demonstrates how a beginner DBA can set up daily full backups and hourly incremental backups for a large organization using Percona XtraBackup 8.0 with a Percona Server for MySQL 8.0 database server.

Assumptions

  • You have Percona XtraBackup 8.0 installed on your system.
  • You have a Percona Server for MySQL 8.0 database server running.
  • You have created dedicated directories for storing backups:
    • /backups/mysql/full - for daily full backups
    • /backups/mysql/incr - for hourly incremental backups

Daily Full Backup Script

This following script defines the server details like hostname, username, password, data directory, and backup directory. Replace these with your actual values.

  • Defines the server credentials

  • Generates a timestamp with the date command for the full backup filename

  • Uses xtrabackup with the --backup flag for a full backup

  • Specifies the directory to store the backup with --target-dir

  • --datadir points to the location of your MySQL data files.

  • Provides the credentials with --user and --password to access the database server.

  • Echoes a message confirming the successful backup completion.

#!/bin/bash

# Set server details (replace with your actual values)
SERVER_HOST="your_server_hostname"
SERVER_USER="your_db_username"
SERVER_PASSWORD="your_db_password"
DATA_DIR="/var/lib/mysql"  # Replace with your data directory path
BACKUP_DIR="/backups/mysql/full"

# Get current date for filename
TODAY=$(date +%Y-%m-%d)
FULL_BACKUP_FILENAME="${BACKUP_DIR}/${TODAY}"

# Run xtrabackup with full backup command
xtrabackup --backup \
  --target-dir="${FULL_BACKUP_FILENAME}" \
  --datadir="${DATA_DIR}" \
  --user="${SERVER_USER}" \
  --password="${SERVER_PASSWORD}"

echo "Daily full backup completed at $(date)"

Running the Daily Script

You can schedule this script to run automatically using cron. For example, to run it every day at midnight (00:00), add this line to your crontab:

$ 0 0 * * * /path/to/daily_full_backup.sh

Hourly Incremental Backup Script

This script uses the same server details as the daily script. It retrieves the current date and hour for the incremental backup filename. The core command uses xtrabackup with the --backup and --incremental flags for an incremental backup. --target-dir specifies the directory to store the incremental backup. --base-dir points to the latest full backup directory obtained using ls and tail commands. This ensures the incremental backup references the most recent full backup. Similar to the daily script, it echoes a confirmation message.

#!/bin/bash

# Set server details (same as daily script)
SERVER_HOST="your_server_hostname"
SERVER_USER="your_db_username"
SERVER_PASSWORD="your_db_password"
DATA_DIR="/var/lib/mysql"  # Replace with your data directory path
BACKUP_DIR="/backups/mysql/incr"

# Get current date and hour for filename
TODAY=$(date +%Y-%m-%d)
HOUR=$(date +%H)  # Get current hour (00-23)
INCR_BACKUP_FILENAME="${BACKUP_DIR}/${TODAY}_${HOUR}"

# Set the base directory for incremental backups (point to the latest full backup)
BASE_DIR="/backups/mysql/full/$(ls -tr /backups/mysql/full | tail -n 1)"

# Run xtrabackup with incremental backup command
xtrabackup --backup \
  --incremental \
  --target-dir="${INCR_BACKUP_FILENAME}" \
  --base-dir="${BASE_DIR}" \
  --user="${SERVER_USER}" \
  --password="${SERVER_PASSWORD}"

echo "Hourly incremental backup completed at $(date)"

Run the Hourly Script

Schedule this script to run every hour using cron.

$ 0 * * * * /path/to/your/script.sh

Last update: 2024-03-28