#!/bin/bash
# 要備份的資料庫名,多個資料庫用空格分開
databases=(db1 db2 db3)
# 備份檔案要儲存的目錄
basepath='/root/backup/b3log.org/mysql/'
if [ ! -d "$basepath" ]; then
mkdir -p "$basepath"
fi
# 循環databases數組
for db in ${databases[*]}
do
# 備份資料庫生成SQL檔案
/bin/nice -n 19 /usr/bin/mysqldump -uUSER -pPASSWORD --database $db > $basepath$db-$(date +%Y%m%d).sql
# 将生成的SQL檔案壓縮
/bin/nice -n 19 tar zcvf $basepath$db-$(date +%Y%m%d).sql.tar.gz $basepath$db-$(date +%Y%m%d).sql
# 删除7天之前的備份資料
find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} \;
done
# 删除生成的SQL檔案
rm -rf $basepath/*.sql
其中備份目錄、MySQL 密碼需要配置。
給權限:chmod a+x /root/backup_mysql.sh
然後使用 crontab 設定該腳本定時執行:
設定為淩晨 3 點執行:
0 3 * * * /root/backup_mysql.sh
轉自:http://88250.b3log.org
本文轉自飛奔的小GUI部落格51CTO部落格,原文連結http://blog.51cto.com/9237101/1913079如需轉載請自行聯系原作者
ziwenzhou