Linux實現定時備份MySQL數據庫並刪除30天前的備份文件


1. MySQL5.6以上版本

2. 修改 /etc/my.cnf 文件

# vim /etc/my.cnf

[client]
host=localhost
user=你的數據庫用戶
password='你的數據庫密碼'

 

3. 編寫數據庫腳本 mysql-backup.sh

# vim mysql-backup.sh
#!/bin/bash

backupDir=數據庫備份目錄
backupTime=`date +%Y%m%d%H%M%S`

mysqldump 你的數據庫 | gzip > $backupDir/你的數據庫-$backupTime.sql.gz
echo "1."$backupTime "備份完成" >> #backupDir/mysql.log

cd $backupDir
rm -rf `find . -name '*.sql.gz' -mtime +30` >> #backupDir/mysql.log 2>&1    #刪除30天前備份文件
echo "2.刪除30天前的備份文件完成" >> #backupDir/mysql.log

 

4. 為腳本添加執行權限

# chmod +x mysql-backup.sh

 

5. 測試執行

./mysql-backup.sh

 

6. 添加定時計划

# crontab -e (和vim編輯器一樣)
# crontab配置文件格式:分 時 日 月 周  命令

# 在最后一行中加入:
0 3 * * *   /usr/sbin/mysql-bakup.sh #表示每天3點00分執行備份
0 */6 * * * /usr/sbin/mysql-bakup.sh #表示每6個小時執行備份

 

7. 重啟crontab

# /etc/rc.d/init.d/crond restart

 

8. 恢復數據庫備份文件

#SQL備份文件恢復:
mysql -u root -p 你的數據庫 < 備份文件名.sql

#壓縮文件恢復:
gzip < 備份文件名.sql.gz | mysql -u root -p 你的數據庫

 

9. 附:如果出現問題:"mysqldump: command not found",解決如下:

ln -fs /usr/local/mysql/bin/mysqldump /usr/bin
ln -fs /usr/local/mysql/bin/mysql /usr/bin

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM