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個小時執行備份
# crontab -l 列出所有定時任務
7. 重啟crontab
# /etc/rc.d/init.d/crond restart
注:Centos8執行crond命令
systemctl restart crond.service #支援的命令有:start、stop、restart、reload、status
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