当ブログのデータベースバックアップを自動化したので、その覚え書きです。
環境
1 2 3 4 |
# 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とします。
1 2 |
[mysqldump] password=passwd |
.my.confファイルの権限を600に変更する
1 |
# chmod 600 .my.conf |
圧縮バックアップのコマンド
1 |
mysqldump --defaults-file=/home/user_name/.my.cnf -u user_name --databases db_name | gzip > mysqldump.sql.gz |
シェルスクリプトの作成
cronで実行するシェルスクリプトを作成し、毎日バックアップを作成しても良いように、日付を付与してバックアップを残せるようにします。
backup_db.sh
1 2 3 4 |
# !/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} |
スクリプトに実行権限を付与する
1 |
# chmod u+x backup_db.sh |
動作確認
シェルスクリプトの通り、/dump_backupフォルダにwordpress日付.dump.gzが作成されればOK。
1 |
# ./backup_db.sh |
cronの設定
作成したシェルスクリプトをcronで実行できるようにします。
1 |
# vi /etc/crontab |
1 |
# crontab -e |
最下行に00 05 * * * ./backup_db.shを追記します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
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を再起動する
1 |
# systemctl restart crond |
コメント