国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

講解Linux系統(tǒng)下如何自動備份MySQL數(shù)據(jù)的基本教程

2024-07-24 13:08:33
字體:
供稿:網(wǎng)友
這篇文章主要介紹了Linux系統(tǒng)下如何自動備份MySQL數(shù)據(jù)的基本教程,還給出了利用shell腳本全備份和增量備份的基本方法,需要的朋友可以參考下
 

1.先創(chuàng)建一個數(shù)據(jù)庫備份目錄:

mkdir backupcd backupmkdir mysqlbackupcd mysqlbackup

2.創(chuàng)建備份腳本

vi mysqlautobackup

3.編寫腳本:

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


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

chmod +x autobackup


5.寫入計劃任務(wù):

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


每天凌晨1點(diǎn)零1分執(zhí)行腳本。
重啟計劃任務(wù):

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


至此所有步驟完成。

一些常用技巧
1、創(chuàng)建保存?zhèn)浞菸募穆窂?mysqldata

#mkdir /mysqldata

2、創(chuàng)建/usr/sbin/baktest文件
輸入以下內(nèi)容:

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

3、修改文件屬性,使其可以執(zhí)行

#chmod +x /usr/sbin/baktest

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

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

表示每天3點(diǎn)鐘01分執(zhí)行備份

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=rootuserPWD=密碼#定義要備份的數(shù)據(jù)庫database=數(shù)據(jù)庫#定義完全備份文件存放路徑bakDir=/backup/mysql#eMailFile=$bakDir/email.txt#eMail=admin@zxsdw.com#定義日志文件LogFile=$bakDir/mysqlbak.logDATE=`date +%Y%m%d`echo " " >> $LogFileecho " " >> $LogFileecho "--------------------------" >> $LogFileecho $(date +"%y-%m-%d %H:%M:%S") >>$LogFileecho "-----------------" >> $LogFilecd $bakDirDumpFile=$DATE.sql.gzmysqldump --flush-logs -u$user -p$userPWD --quick $database| gzip >$DumpFileecho "Dump Done" >> $LogFileecho "[$DumpFile]Backup Success!" >> $LogFiledaily_databakDir=$bakDir/daily_backupcd $bakDir/daily_backupfind $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#定義數(shù)據(jù)庫用戶名及密碼user=rootuserPWD=密碼#定義數(shù)據(jù)庫database=數(shù)據(jù)庫#生成一個新的mysql-bin.00000X文件,如果err日志被清除,則自動新建一個。/usr/local/mysql/bin/mysqladmin -u$user -p$userPWD flush-logs#定義增量備份位置daily_databakDir=/backup/mysql/daily_backup#定義MYSQL數(shù)據(jù)日志目錄mysqlDataDir=/usr/local/mysql/var#定義增量日志及目錄eMailFile=$daily_databakDir/email.txt#eMail=admin@zxsdw.com#定義變量DATE格式為20150127DATE=`date +%Y%m%d`#定義一個總的logFile日志logFile=$daily_databakDir/mysql$DATE.log#美化日志模板echo "    " > $eMailFileecho "-----------------------" >> $eMailFile#時間格式為15-01-27 01:06:17echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFileecho "-------------------------" >> $eMailFile#定義刪除bin日志的時間范圍,格式為20150124010540TIME=$(date "-d 3 day ago" +%Y%m%d%H%M%S)#定義需要增量備份數(shù)據(jù)的時間范圍,格式為2015-01-26 01:04:11StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")###########開始刪除操作美化日志標(biāo)題##############echo "Delete 3 days before the log" >>$eMailFile#刪除三天前的bin文件,及更新index里的索引記錄,美化日志標(biāo)題mysql -u$user -p$userPWD -e "purge master logs before ${TIME}" && echo "delete 3 days before log" |tee -a $eMailFile#查找index索引里的bin 2進(jìn)制文件并賦值給 i。filename=`cat $mysqlDataDir/mysql-bin.index |awk -F "/" '{print $2}'`for i in $filenamedo#########開始增量備份操作,美化日志標(biāo)題###########echo "$StartTime start backup binlog" >> $eMailFile#利用mysqlbinlog備份1天前增加的數(shù)據(jù),并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 $eMailFiledone#如果以上備份腳本執(zhí)行成功,接著運(yùn)行下面的刪除腳本if [ $? = 0 ]then# 刪除mtime>32的增量日志備份文件find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} /; > /dev/null 2>&1cd $daily_databakDirecho "Daily backup succeed" >> $eMailFileelseecho "Daily backup fail" >> $eMailFile#mail -s "MySQL Backup" $eMail < $eMailFile #備份失敗之后發(fā)送郵件通知#fi結(jié)束IF判斷fi#把變量eMailFile的內(nèi)容替換logFile內(nèi)容cat $eMailFile > $logFile#如果上面的IF判斷失敗,再次運(yùn)行刪除mtime>32的增量日志備份文件find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} /; > /dev/null 2>&1rsync -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密碼 數(shù)據(jù)庫名 --force--force參數(shù) 忽略錯誤


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 乌恰县| 友谊县| 长武县| 蕉岭县| 桂阳县| 福清市| 平原县| 文水县| 南岸区| 青海省| 苍南县| 普陀区| 彰武县| 凉城县| 高邮市| 隆安县| 日土县| 荔波县| 长葛市| 鸡西市| 湘潭市| 汝州市| 如东县| 财经| 鹤山市| 平定县| 蓝山县| 岑溪市| 潼关县| 呼图壁县| 普定县| 云南省| 永登县| 湘潭县| 绥芬河市| 丰城市| 山阳县| 东光县| 万盛区| 台中县| 睢宁县|