CentOS7下 MySQL定時(shí)自動(dòng)備份的實(shí)現(xiàn)方法
生產(chǎn)環(huán)境遇到得最幸福得事情就是,某些場(chǎng)景沒辦法避免去update或者delete的時(shí)候,某個(gè)參數(shù)沒有注意。完蛋了 完蛋了,數(shù)據(jù)被我搞崩了怎么辦,趕緊去運(yùn)營(yíng)找備份呀!運(yùn)營(yíng)說(shuō):狗屁 咱們系統(tǒng)從來(lái)不備份,你說(shuō):那把日志給我吧,運(yùn)營(yíng)說(shuō):狗屁 每天上G的日志,我都沒給你開,你說(shuō):怎么辦,數(shù)據(jù)庫(kù)被我搞崩了。運(yùn)營(yíng)說(shuō):那是你的事,跟我沒關(guān)系........這是某公司的一段寫照,所以今天我們來(lái)把這個(gè)情況給杜絕
今天要給客戶部署一套系統(tǒng),使用的MySQL5.7,那客戶那邊的開發(fā)人員我可不敢保證他們的能力咋樣。我只能給他們?nèi)块_機(jī)自啟、數(shù)據(jù)庫(kù)等重要文件自動(dòng)備份好,一旦出什么幺蛾子。咱風(fēng)淡云輕的一行命令給搞定,這是一個(gè)負(fù)責(zé)任的做法。準(zhǔn)備開始:
我們需要實(shí)現(xiàn)下面的幾個(gè)功能:
第一:數(shù)據(jù)庫(kù)備份
第二:數(shù)據(jù)庫(kù)通過(guò)備份恢復(fù)
第三:數(shù)據(jù)庫(kù)備份自動(dòng)化
第四:清理過(guò)期備份文件
第一:數(shù)據(jù)庫(kù)自動(dòng)備份
1.創(chuàng)建備份目錄
這里我選擇了把備份文件放在 /data/backup/mysql下面,把腳本放在 /data/backup 下面:
[root@izwz99z5o9dc90keftqhlrz /]# mkdir -p /data/backup/mysql [root@izwz99z5o9dc90keftqhlrz /]# cd /data/backup
2.創(chuàng)建腳本文件
創(chuàng)建mysql_backup.sh
[root@izwz99z5o9dc90keftqhlrz backup]# vi mysql_backup.sh #!/bin/bash # db_name 自己改這里哦 db_name='baizhan' backup_dir='/data/backup/mysql/' current_time=$(date +'%Y-%m-%d_%H%M%S') filepath=$backup_dir$current_time'.sql.gz' #此處沒有使用 $db_password $db_user, 已經(jīng)寫入到配置文件中 echo '開始導(dǎo)出數(shù)據(jù)庫(kù)...' mysqldump --defaults-extra-file=/data/backup/my_mysql.cnf $db_name | gzip > $filepath echo '導(dǎo)出成功,文件名為: '$filepath
3.新建配置文件
就在我們的當(dāng)前目錄下 即 /data/backup
[root@izwz99z5o9dc90keftqhlrz backup]# vi my_mysql.cnf [mysqldump] max_allowed_packet = 400M host=127.0.0.1 user=root password='SgDGfsrfEi3#@%#%ugslp%z!dAP' [mysql] host=127.0.0.1 user=root password='SgDGfsrfEi3#@%#%ugslp%z!dAP'
各位看官請(qǐng)把上面的參數(shù)改成自己的就好了,可別漏了這一步哦
其中 mysqldump 下的參數(shù)是給導(dǎo)出的命令使用的,mysql 下的參數(shù)是導(dǎo)入的時(shí)候使用的
4.給文件權(quán)限
到這里的話導(dǎo)出的shell腳本就已經(jīng)寫好了,我們對(duì)這個(gè)腳本加一下可執(zhí)行權(quán)限
[root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_backup.sh
5.執(zhí)行一下我們的命令
[root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_backup.sh # 查看一下結(jié)果 [root@izwz99z5o9dc90keftqhlrz backup]# ll ./mysql

6.擴(kuò)展使用
我們解壓一下已經(jīng)成功導(dǎo)出的文件,看看原文件大小和壓縮后的文件大小對(duì)比
[root@izwz99z5o9dc90keftqhlrz backup]# gzip -dc ./mysql/2019-12-22_180359.sql.gz > ./mysql/2019-12-22_180359.sql [root@izwz99z5o9dc90keftqhlrz backup]# ll -sh ./mysql total 44K 36K -rw-r--r-- 1 root root 36K Dec 22 18:06 2019-12-22_180359.sql 8.0K -rw-r--r-- 1 root root 5.9K Dec 22 18:03 2019-12-22_180359.sql.gz 36Kb 和8Kb的對(duì)比,如果數(shù)據(jù)庫(kù)比較大的話,更能節(jié)省空間
到這里為止,我們的導(dǎo)出腳本已經(jīng)完成了,接下來(lái)就是導(dǎo)入腳本了
第二:數(shù)據(jù)庫(kù)通過(guò)備份恢復(fù)
1.創(chuàng)建腳本文件
按照第一步的操作,此時(shí)我們應(yīng)該處于 /data/backup 目錄下,繼續(xù)操作
[root@izwz99z5o9dc90keftqhlrz backup]# vi mysql_restore.sh
#!/bin/bash
if [ -z $1 ] || [ ! -f $1 ]
then
echo "請(qǐng)輸入sql壓縮文件(*.sql.gz)"
exit 1
fi
#輸入你自己的數(shù)據(jù)庫(kù)名稱
db_name='jx_guides'
base_dir='/data/backup/mysql/'
gz_sql_file=`basename $1`
file_ext=${gz_sql_file##*.}
if [ $file_ext != 'gz' ]
then
echo '文件格式不正確,請(qǐng)輸入 .sql.gz 文件'
exit 1
fi
sql_file=${gz_sql_file%.*}
echo '解壓文件中...'
gzip -dc $base_dir$gz_sql_file > $base_dir$sql_file
echo '解壓完成.'
echo '開始導(dǎo)入數(shù)據(jù)庫(kù)...'
mysql --defaults-extra-file=/data/backup/my_mysql.cnf $db_name < $base_dir$sql_file
if [ -f $base_dir$sql_file ]
then
echo '刪除臨時(shí)文件.'
rm -f $base_dir$sql_file
fi
echo '導(dǎo)入完成.'
上面代碼中的配置文件,就是我們第一步時(shí)創(chuàng)建的配置文件,在這里一樣的使用
2.增加文件可執(zhí)行權(quán)限
[root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_restore.sh
3.我們來(lái)執(zhí)行通過(guò)備份文件恢復(fù)數(shù)據(jù)庫(kù)
[root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_restore.sh ./mysql/2019-12-22_180359.sql.gz
解壓文件中...
解壓完成.
開始導(dǎo)入數(shù)據(jù)庫(kù)...
刪除臨時(shí)文件.
導(dǎo)入完成.
在這里我們的第一個(gè)參數(shù)可以直接寫備份文件的名字,不用寫目錄,但是因?yàn)榧由夏夸浿螅梢允褂胻able進(jìn)行自動(dòng)補(bǔ)全,所以十分方便,其他的執(zhí)行方式:其實(shí)懂的人知道都一樣
其實(shí)可以在任何文件夾進(jìn)行恢復(fù),執(zhí)行 這個(gè)可以在任意位置執(zhí)行
[root@izwz99z5o9dc90keftqhlrz backup]# sh /data/backup/mysql_restore.sh /data/backup/mysql/2019-12-22_180359.sql.gz 也可以這樣 [root@izwz99z5o9dc90keftqhlrz mysql]# pwd /data/backup/mysql [root@izwz99z5o9dc90keftqhlrz mysql]# sh /data/backup/mysql_restore.sh 2019-12-22_180359.sql.gz
第三:數(shù)據(jù)庫(kù)備份自動(dòng)化
1.添加計(jì)劃任務(wù)
[root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e # 粘貼下面的內(nèi)容, 數(shù)據(jù)庫(kù)自動(dòng)備份 0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1點(diǎn),中午12點(diǎn)備份一次數(shù)據(jù)
第四:清理過(guò)期備份文件
1.創(chuàng)建刪除文件腳本
[root@izwz99z5o9dc90keftqhlrz mysql]# vi remove_backup.sh #/bin/bash # 刪除15天前的備份 find /data/backup/mysql -type f -mtime +15 | xargs rm -f
我這里是選擇備份數(shù)據(jù)只保留最近15天的,大家根據(jù)需要自行修改
2.添加可執(zhí)行權(quán)限
[root@izwz99z5o9dc90keftqhlrz mysql]# chmod +x ./remove_backup.sh #手動(dòng)刪除 15天前的備份 [root@izwz99z5o9dc90keftqhlrz mysql]# ./remove_backup.sh
3.自動(dòng)清理
[root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e # 下面這個(gè)就是腳本內(nèi)容哦,添加這一句 0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1點(diǎn),自動(dòng)刪除15天[15是remove_backup.sh里面配置的]前的備份
第五:定時(shí)任務(wù)配置給貼出來(lái)
# 粘貼下面的內(nèi)容, 數(shù)據(jù)庫(kù)自動(dòng)備份 0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1點(diǎn),中午12點(diǎn)備份一次數(shù)據(jù) # 下面這個(gè)就是腳本內(nèi)容哦,添加這一句 0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1點(diǎn),自動(dòng)刪除15天[15是remove_backup.sh里面配置的]前的備份
總結(jié)
以上所述是小編給大家介紹的CentOS7下 MySQL定時(shí)自動(dòng)備份的實(shí)現(xiàn)方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- 詳解Mysql自動(dòng)備份與恢復(fù)的幾種方法(圖文教程)
- linux下mysql自動(dòng)備份腳本代碼
- mysql定時(shí)自動(dòng)備份數(shù)據(jù)庫(kù)的方法步驟
- linux實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)每天自動(dòng)備份定時(shí)備份
- MySQL數(shù)據(jù)庫(kù)的shell腳本自動(dòng)備份
- 8種手動(dòng)和自動(dòng)備份MySQL數(shù)據(jù)庫(kù)的方法
- windows mysql 自動(dòng)備份的幾種方法匯總
- linux下mysql如何自動(dòng)備份shell腳本
- mysql自動(dòng)備份多個(gè)數(shù)據(jù)庫(kù)的實(shí)現(xiàn)
相關(guān)文章
MySQL 使用SQL語(yǔ)句修改表名的實(shí)現(xiàn)
這篇文章主要介紹了MySQL 使用SQL語(yǔ)句修改表名的實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04
修改Mysql索引長(zhǎng)度限制解決767?byte限制問(wèn)題
這篇文章主要介紹了修改Mysql索引長(zhǎng)度限制解決767?byte限制問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
詳解MySQL數(shù)據(jù)備份之mysqldump使用方法
本篇文章主要介紹了MySQL數(shù)據(jù)備份,詳細(xì)的介紹了mysqldump的各種用法,具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11
Mysql 5.7從節(jié)點(diǎn)配置多線程主從復(fù)制的方法詳解
這篇文章主要介紹了Mysql 5.7從節(jié)點(diǎn)配置多線程主從復(fù)制的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-03-03
MySQL 如何查找并刪除重復(fù)記錄的實(shí)現(xiàn)
這篇文章主要介紹了MySQL 如何查找并刪除重復(fù)記錄的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
淺談MySQL數(shù)據(jù)查詢太多會(huì)OOM嗎
本文主要介紹了淺談MySQL數(shù)據(jù)查詢太多會(huì)OOM嗎?文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
在MySQL中創(chuàng)建帶有IN和OUT參數(shù)的存儲(chǔ)過(guò)程的方法
這篇文章主要介紹了在MySQL中創(chuàng)建帶有IN和OUT參數(shù)的存儲(chǔ)過(guò)程的方法,在一定程度上簡(jiǎn)化了操作,需要的朋友可以參考下2015-06-06
一步步教你在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句
很多時(shí)候我們會(huì)提交一些耗時(shí)比較長(zhǎng)的sql,可能出現(xiàn)mysql服務(wù)器內(nèi)存或者CPU暴增,引起報(bào)警,甚至影響其他業(yè)務(wù),下面這篇文章主要給大家介紹了關(guān)于在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句的相關(guān)資料,需要的朋友可以參考下2023-03-03

