講解Linux系統(tǒng)下如何自動(dòng)備份MySQL數(shù)據(jù)的基本教程
1.先創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)備份目錄:
mkdir backup cd backup mkdir mysqlbackup cd mysqlbackup
2.創(chuàng)建備份腳本
vi mysqlautobackup
3.編寫腳本:
filename=`date +%Y%m%d` /mysql的bin目錄/mysqldump --opt 數(shù)據(jù)庫(kù)名 -u(mysql賬號(hào)) -p(mysql密碼) | gzip > /備份到哪個(gè)目錄/name$filename.gz
說(shuō)明:以上采用gzip壓縮,name可隨意寫,注意-u與mysql賬號(hào)之間沒(méi)有空格也無(wú)需括號(hào),-p與mysql密碼也是。
4.將腳本設(shè)置為可執(zhí)行權(quán)限:
chmod +x autobackup
5.寫入計(jì)劃任務(wù):
crontab -e 01 01 * * * /bin/bash /腳本所在目錄/mysqlautobackup
每天凌晨1點(diǎn)零1分執(zhí)行腳本。
重啟計(jì)劃任務(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、重新啟動(dòng)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=密碼 #定義要備份的數(shù)據(jù)庫(kù) database=數(shù)據(jù)庫(kù) #定義完全備份文件存放路徑 bakDir=/backup/mysql #eMailFile=$bakDir/email.txt #eMail=admin@zxsdw.com #定義日志文件 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 #定義數(shù)據(jù)庫(kù)用戶名及密碼 user=root userPWD=密碼 #定義數(shù)據(jù)庫(kù) database=數(shù)據(jù)庫(kù) #生成一個(gè)新的mysql-bin.00000X文件,如果err日志被清除,則自動(dòng)新建一個(gè)。 /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格式為20150127 DATE=`date +%Y%m%d` #定義一個(gè)總的logFile日志 logFile=$daily_databakDir/mysql$DATE.log #美化日志模板 echo " " > $eMailFile echo "-----------------------" >> $eMailFile #時(shí)間格式為15-01-27 01:06:17 echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile echo "-------------------------" >> $eMailFile #定義刪除bin日志的時(shí)間范圍,格式為20150124010540 TIME=$(date "-d 3 day ago" +%Y%m%d%H%M%S) #定義需要增量備份數(shù)據(jù)的時(shí)間范圍,格式為2015-01-26 01:04:11 StartTime=$(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 $filename do #########開始增量備份操作,美化日志標(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 $eMailFile done #如果以上備份腳本執(zhí)行成功,接著運(yùn)行下面的刪除腳本 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 #備份失敗之后發(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>&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密碼 數(shù)據(jù)庫(kù)名 --force --force參數(shù) 忽略錯(cuò)誤
- 在Linux系統(tǒng)上部署Apache+Python+Django+MySQL環(huán)境
- Linux+Nginx+MySQL下配置論壇程序Discuz的基本教程
- MySQL的一些功能實(shí)用的Linux shell腳本分享
- Linux下將數(shù)據(jù)庫(kù)從MySQL遷移到MariaDB的基礎(chǔ)操作教程
- mysql忘記密碼怎么辦(windows linux)
- linux下python3連接mysql數(shù)據(jù)庫(kù)問(wèn)題
- linux mint 下mysql中文支持問(wèn)題
- Linux系統(tǒng)上配置Nginx+Ruby on Rails+MySQL超攻略
- Linux系統(tǒng)下自行編譯安裝MySQL及基礎(chǔ)配置全過(guò)程解析
相關(guān)文章
mysql隨機(jī)查詢?nèi)舾蓷l數(shù)據(jù)的方法
這篇文章主要介紹了mysql中獲取隨機(jī)內(nèi)容的方法,需要的朋友可以參考下2013-10-10mysql-5.5.28源碼安裝過(guò)程中錯(cuò)誤總結(jié)
介紹一下關(guān)于mysql-5.5.28源碼安裝過(guò)程中幾大錯(cuò)誤總結(jié),希望此文章對(duì)各位同學(xué)有所幫助。2013-10-10Mysql之如何實(shí)現(xiàn)行列轉(zhuǎn)換
這篇文章主要介紹了Mysql之如何實(shí)現(xiàn)行列轉(zhuǎn)換問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06MySQL數(shù)據(jù)庫(kù)配置優(yōu)化的方案
我們總是希望MySQL能夠獲得更高的查詢性能,最好的辦法是弄清楚MySQL是如何優(yōu)化和執(zhí)行查詢的。本文講解MySQL在各個(gè)方面的優(yōu)化方向,方便后端開發(fā)人員在調(diào)優(yōu)和問(wèn)題排查過(guò)程中找到切入點(diǎn)2023-02-02mysql優(yōu)化之慢查詢分析+explain命令分析+優(yōu)化技巧總結(jié)
這篇文章主要介紹了mysql優(yōu)化之慢查詢分析,explain命令分析,優(yōu)化技巧總結(jié),需要的朋友可以參考下2023-02-02MySQL for update鎖表還是鎖行校驗(yàn)(過(guò)程詳解)
在MySQL中,使用for update子句可以對(duì)查詢結(jié)果集進(jìn)行行級(jí)鎖定,以便在事務(wù)中對(duì)這些行進(jìn)行更新或者防止其他事務(wù)對(duì)這些行進(jìn)行修改,這篇文章主要介紹了MySQL for update鎖表還是鎖行校驗(yàn),需要的朋友可以參考下2024-02-02innodb 庫(kù)的備份注意點(diǎn)(由phpmyadmin引起的解決方案)
新版本xampps 1.8.5 X64 集成了phpmyadmin最新版本(4.1.0), 可每次初始化安裝程序后, 進(jìn)入phpmyadmin管理工具, 就會(huì)發(fā)現(xiàn)phpmyadmin高級(jí)功能失效, 一直在提示數(shù)據(jù)表不存在, 經(jīng)過(guò)再三的分析, 終于找到原因2013-12-12