程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 講解Linux系統下如何自動備份MySQL數據的基本教程

講解Linux系統下如何自動備份MySQL數據的基本教程

編輯:關於MYSQL數據庫

1.先創建一個數據庫備份目錄:

mkdir backup
cd backup
mkdir mysqlbackup
cd mysqlbackup

2.創建備份腳本

vi mysqlautobackup

3.編寫腳本:

filename=`date +%Y%m%d`
/mysql的bin目錄/mysqldump --opt 數據庫名 -u(mysql賬號) -p(mysql密碼) | gzip > /備份到哪個目錄/name$filename.gz


說明:以上采用gzip壓縮,name可隨意寫,注意-u與mysql賬號之間沒有空格也無需括號,-p與mysql密碼也是。
4.將腳本設置為可執行權限:

chmod +x autobackup


5.寫入計劃任務:

crontab -e
01 01 * * * /bin/bash /腳本所在目錄/mysqlautobackup


每天凌晨1點零1分執行腳本。
重啟計劃任務:

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


至此所有步驟完成。

一些常用技巧
1、創建保存備份文件的路徑/mysqldata

#mkdir /mysqldata

2、創建/usr/sbin/baktest文件
輸入以下內容:

mysqldump -uroot -proot test | gzip > /mysqldata/test`date +%Y-%m-%d_%H%M%S`.sql.gz

3、修改文件屬性,使其可以執行

#chmod +x /usr/sbin/baktest

4、修改/etc/crontab
在下面添加

01 3 * * * root /usr/sbin/baktest

表示每天3點鐘01分執行備份

5、重新啟動crond

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

完成。


PS:
全備份腳本:

#!/bin/bash
# Name:qbk全備份腳本
# mysql qbk scripts
# By zxsdw.com
# Last Modify:2015-01-21
#定義腳本存放路徑
#scriptsDir=/usr/sbin
#定義用戶名及密碼
user=root
userPWD=密碼
#定義要備份的數據庫
database=數據庫
#定義完全備份文件存放路徑
bakDir=/backup/mysql
#eMailFile=$bakDir/email.txt
#[email protected]
#定義日志文件
LogFile=$bakDir/mysqlbak.log
DATE=`date +%Y%m%d`
echo " " >> $LogFile
echo " " >> $LogFile
echo "--------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >>$LogFile
echo "-----------------" >> $LogFile
cd $bakDir
DumpFile=$DATE.sql.gz
mysqldump --flush-logs -u$user -p$userPWD --quick $database| gzip >$DumpFile
echo "Dump Done" >> $LogFile
echo "[$DumpFile]Backup Success!" >> $LogFile
daily_databakDir=$bakDir/daily_backup
cd $bakDir/daily_backup
find $daily_databakDir -name "daily*" -type f -mtime +35 -exec rm {} \; > /dev/null 2>&1


增量備份腳本

#!/bin/bash
# Name:zbk增量備份
# mysql zbk scripts
# By zxsdw.com
# Last modify:2015-01-21


#定義數據庫用戶名及密碼
user=root
userPWD=密碼
#定義數據庫
database=數據庫
#生成一個新的mysql-bin.00000X文件,如果err日志被清除,則自動新建一個。
/usr/local/mysql/bin/mysqladmin -u$user -p$userPWD flush-logs
#定義增量備份位置
daily_databakDir=/backup/mysql/daily_backup
#定義MYSQL數據日志目錄
mysqlDataDir=/usr/local/mysql/var
#定義增量日志及目錄
eMailFile=$daily_databakDir/email.txt
#[email protected]
#定義變量DATE格式為20150127
DATE=`date +%Y%m%d`
#定義一個總的logFile日志
logFile=$daily_databakDir/mysql$DATE.log


#美化日志模板
echo "    " > $eMailFile
echo "-----------------------" >> $eMailFile
#時間格式為15-01-27 01:06:17
echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile
echo "-------------------------" >> $eMailFile


#定義刪除bin日志的時間范圍,格式為20150124010540
TIME=$(date "-d 3 day ago" +%Y%m%d%H%M%S)
#定義需要增量備份數據的時間范圍,格式為2015-01-26 01:04:11
StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")

###########開始刪除操作美化日志標題##############
echo "Delete 3 days before the log" >>$eMailFile

#刪除三天前的bin文件,及更新index裡的索引記錄,美化日志標題
mysql -u$user -p$userPWD -e "purge master logs before ${TIME}" && echo "delete 3 days before log" |tee -a $eMailFile

#查找index索引裡的bin 2進制文件並賦值給 i。
filename=`cat $mysqlDataDir/mysql-bin.index |awk -F "/" '{print $2}'`
for i in $filename
do
#########開始增量備份操作,美化日志標題###########
echo "$StartTime start backup binlog" >> $eMailFile

#利用mysqlbinlog備份1天前增加的數據,並gzip壓縮打包到增量備份目錄
/usr/local/mysql/bin/mysqlbinlog -u$user -p$userPWD -d $database --start-datetime="$StartTime" $mysqlDataDir/$i |gzip >> $daily_databakDir/daily$DATE.sql.gz |tee -a $eMailFile

done


#如果以上備份腳本執行成功,接著運行下面的刪除腳本
if [ $? = 0 ]
then
# 刪除mtime>32的增量日志備份文件
find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
cd $daily_databakDir
echo "Daily backup succeed" >> $eMailFile
else
echo "Daily backup fail" >> $eMailFile
#mail -s "MySQL Backup" $eMail < $eMailFile #備份失敗之後發送郵件通知
#fi結束IF判斷
fi


#把變量eMailFile的內容替換logFile內容
cat $eMailFile > $logFile

#如果上面的IF判斷失敗,再次運行刪除mtime>32的增量日志備份文件
find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
rsync -vzrtopg --delete --progress --password-file=/usr/local/rsync/rsync.passwd root@$ip:/zxs/allimg/$(date -d -1day +%y%m%d) /zxs/allimg/
gunzip < /backup/mysql/daily_backup/ceshi.sql.gz | /usr/local/mysql/bin/mysql -u用戶名 -p密碼 數據庫名 --force
--force參數 忽略錯誤

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved