Скрипт для создания резервной копии MySQL

  • Михаил
  • 12 мин. на прочтение
  • 121
  • 25 Nov 2022
  • 25 Nov 2022

Данный скрипт написан на Unix Shell под управлением операционной системы CentOS. Он будет работать на большинстве систем семейств Linux и BSD.

Пример скрипта

Скрипт будет создавать для каждой базы свой дамп. Это необходимо для быстрого восстановления данных.

Создаем каталог для скриптов и сам скрипт:

mkdir /scripts
vi /scripts/mysql_backup.sh
#!/bin/bash
PATH=/etc:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin

destination="/backup/mysql"
userDB="backup"
passwordDB="backup"
fdate=`date +%Y-%m-%d`

find $destination -type d \( -name "*-1[^5]" -o -name "*-[023]?" \) -mtime +30 -exec rm -R {} \; 2>&1
find $destination -type d -name "*-*" -mtime +180 -exec rm -R {} \; 2>&1
test -d $destination/$fdate || mkdir $destination/$fdate 2>&1

for dbname in `echo show databases | mysql -u$userDB -p$passwordDB | grep -v Database`; do
   case $dbname in
       information_schema)
           continue ;;
       mysql)
           continue ;;
       performance_schema)
           continue ;;
       test)
           continue ;;
       sys)
           continue ;;
       *) mysqldump --databases --skip-comments --no-tablespaces -u$userDB -p$passwordDB $dbname | gzip > $destination/$fdate/$dbname.sql.gz ;;
   esac
done;

Задаем права скрипту на выполнение:

chmod +x /scripts/mysql_backup.sh

Описание скрипта

1Указываем на путь к интерпретатору.
2Задаем системные переменные, чтобы не пришлось в скрипте прописывать полные пути до исполняемых файлов.
4 - 7Задаем переменные.
4Каталог, в котором будем сохранять резервные копии.
5Учетная запись для подключения к базе данных.
6Пароль для подключения к базе данных.
7Дата, когда запускается скрипт.
9Находим все резервные копии, которые старше 30 дней и удаляем их. Оставаляем для архива файлы на 15 число.
10Удаляем все резервные копии старше 180 дней.
11Создаем каталог (если его нет), в который будем сохранять резервные копии. В качестве имени каталога используем дату запуска скрипта в формате ГГГГ-MM-ДД.
13 - 25Подключаемся к базе данных и вытаскиваем список всех баз данных. Для каждой делаем резервную копию.
15 - 22Пропускаем служебные базы information_schema, mysql, performance_schema, test.
23Делаем резервную копию для баз.

Подготовка системы

Подключаемся к базе данных и создаем учетную запись с правом на создание резервных копий:

mysql -uroot -p
> GRANT SELECT, SHOW VIEW, RELOAD, REPLICATION CLIENT, EVENT, TRIGGER, LOCK TABLES, PROCESS ON *.* TO backup@localhost IDENTIFIED BY 'backup';

* в данном примере мы создаем учетную запись backup с паролем backup.

Создаем каталог, в котором будут храниться резервные копии:

mkdir -p /backup/mysql

Сохранение данных на удаленном компьютере

Резервные копии необходимо создавать на удаленном компьютере или внешнем диске, чтобы они были доступны при выходе из строя сервера. В данном примере используется общая папка на удаленном сервере, в которой будут размещаться файлы с backup.

Чтобы упростить процесс монтирования сетевой папки, откроем на редактирование следующий файл:

# vi /etc/fstab

и добавим в него следующую строчку:

//192.168.0.1/backup /mnt cifs user,rw,noauto,credentials=/root/.smbclient 0 0

* в данном примере выполняется монтирование общей папки backup на сервере с IP-адресом 192.168.0.1 в каталог /mnt. В качестве сетевой файловой системы используется cifs (протокол SMB: сервер samba или общая папка Windows). Параметры для подключения — user: позволяет выполнить монтирование любому пользователю, rw: с правом на чтение и запись, noauto: не монтировать автоматически при старте системы, credentials: файл, в котором написаны логин и пароль для подключения к общей папке.

Теперь создадим файл с логином и паролем:

# vi /root/.smbclient

и приведем его к следующему виду:

username=backup
password=backup

* username: имя пользователя, password: пароль. Само собой, в вашем случае указываются свои данные.

Теперь введите следующую команду:

# mount /mnt

Должна примонтировать сетевая папка //10.10.0.210/backup. Это можно проверить следующей командой:

# mount

Автоматический запуск по расписанию

Создадим правило в cron для автоматического запуска нашего скрипта. Выполняем команду:

crontab -e

И добавляем строку:

0 3 * * * /scripts/mysql_backup.sh

* в данном примере мы будем запускать резервирование каждый день в 3 часа ночи.