Linux 使用crontab定時備份Mysql數據庫


 項目中數據庫的數據是至關重要的!在實際項目中,遇到有客戶機房斷電導致數據庫數據丟失的問題,又因為備份容災不及時,導致部分數據恢復不了,而剛好這部分丟失的數據對於客戶來說又是至關重要的,那么怎么辦呢?盲羊補牢,為時晚矣!所以,對應日常數據庫的自動備份千萬不能馬虎!首先想到的是,使用Linux的自動定時任務命令crontab對數據庫進行定時備份!

1、在/home/test創建新腳本文件test_database_backup.sh:

 

[root@win7 /]# cd home/test
[root@win7 test]# touch test_database_backup.sh
[root@win7 test]# chmod 770 test_database_backup.sh

 

2、使用VI工具編寫test_database_backup.sh備份數據庫腳本內容:

# Name:test_database_backup.sh
# This is a ShellScript For Auto DB Backup and Delete old Backup
#備份地址
backupdir=/www/test_backup
#備份文件后綴時間
time=_` date +%Y_%m_%d_%H_%M_%S `
#需要備份的數據庫名稱
db_name=test
#mysql 用戶名
#db_user=
#mysql 密碼
#db_pass=
#mysqldump命令使用絕對路徑
/home/server/mysql-5.6.21/bin/mysqldump $db_name | gzip > $backupdir/$db_name$time.sql.gz
#刪除7天之前的備份文件
find $backupdir -name $db_name"*.sql.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1

3、在以上腳本中並沒有填寫db_user,db_pass,那么mysqldump怎么連接數據庫呢?

[root@win7 /]cd /etc
[root@win7 etc]vi my.cnf
[mysqldump]
quick
max_allowed_packet = 16M
#在這里輸入user及password,在執行mysqldump命令就不用輸入用戶名和密碼了
user=root
password=123456

4、使用crontab創建定時任務

[root@win7 /]crontab -e

加入00 02 * * * /usr/bin/sh /home/test/test_database_backup.sh >> /home/test/test_database_backup.log

再用service crond restart重新啟動定時任務服務即可!

 


免責聲明!

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



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