【CentOS 7】データベースの自動バックアップを設定する

当ブログのデータベースバックアップを自動化したので、その覚え書きです。

 

環境

# kusanagi -V
KUSANAGI Version 8.5.3-1
# mysql -V
mysql Ver 15.1 Distrib 10.3.31-MariaDB, for Linux (x86_64) using readline 5.1

 

mysqldumpをパスワードなしで実行できるようにする

.my.confを作成し、パスワードを登録する。

ここではパスワードをpasswdとします。

[mysqldump]
password=passwd

 .my.confファイルの権限を600に変更する

# chmod 600 .my.conf

圧縮バックアップのコマンド

 mysqldump --defaults-file=/home/user_name/.my.cnf -u user_name --databases db_name | gzip > mysqldump.sql.gz 

シェルスクリプトの作成

cronで実行するシェルスクリプトを作成し、毎日バックアップを作成しても良いように、日付を付与してバックアップを残せるようにします。

backup_db.sh

# !/bin/bash

fname="wordpress"$(LANG=en_US.UTF-8 date '+%Y%m%d')".dump.gz"
mysqldump --defaults-file=~/.my.cnf -u root --databases wordpress | gzip > /dump_backup/${fname}

 

スクリプトに実行権限を付与する

# chmod u+x backup_db.sh

 

動作確認

シェルスクリプトの通り、/dump_backupフォルダにwordpress日付.dump.gzが作成されればOK。

# ./backup_db.sh

 

cronの設定

作成したシェルスクリプトをcronで実行できるようにします。

# vi /etc/crontab

 

最下行に00 05 * * * ./backup_db.shを追記します。

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
00 05 * * * ./backup_db.sh

 

cronを再起動する

# systemctl restart crond

Posted by 管理人