当ブログのデータベースバックアップを自動化したので、その覚え書きです。
環境
# 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
コメント