CentOS7下 MySQL定時自動備份的實現方法
生產環境遇到得最幸福得事情就是,某些場景沒辦法避免去update或者delete的時候,某個引數沒有注意。完蛋了 完蛋了,資料被我搞崩了怎麼辦,趕緊去運營找備份呀!運營說:狗屁 咱們系統從來不備份,你說:那把日誌給我吧,運營說:狗屁 每天上G的日誌,我都沒給你開,你說:怎麼辦,資料庫被我搞崩了。運營說:那是你的事,跟我沒關係........這是某公司的一段寫照,所以今天我們來把這個情況給杜絕
今天要給客戶部署一套系統,使用的MySQL5.7,那客戶那邊的開發人員我可不敢保證他們的能力咋樣。我只能給他們全部開機自啟、資料庫等重要檔案自動備份好,一旦出什麼么蛾子。咱風淡雲輕的一行命令給搞定,這是一個負責任的做法。準備開始:
我們需要實現下面的幾個功能:
第一:資料庫備份
第二:資料庫通過備份恢復
第三:資料庫備份自動化
第四:清理過期備份檔案
第一:資料庫自動備份
1.建立備份目錄
這裡我選擇了把備份檔案放在 /data/backup/mysql下面,把指令碼放在 /data/backup 下面:
[root@izwz99z5o9dc90keftqhlrz /]# mkdir -p /data/backup/mysql [root@izwz99z5o9dc90keftqhlrz /]# cd /data/backup
2.建立指令碼檔案
建立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,已經寫入到配置檔案中 echo '開始匯出資料庫...' mysqldump --defaults-extra-file=/data/backup/my_mysql.cnf $db_name | gzip > $filepath echo '匯出成功,檔名為: '$filepath
3.新建配置檔案
就在我們的當前目錄下 即 /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'
各位看官請把上面的引數改成自己的就好了,可別漏了這一步哦
其中 mysqldump 下的引數是給匯出的命令使用的,mysql 下的引數是匯入的時候使用的
4.給檔案許可權
到這裡的話匯出的shell指令碼就已經寫好了,我們對這個指令碼加一下可執行許可權
[root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_backup.sh
5.執行一下我們的命令
[root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_backup.sh # 檢視一下結果 [root@izwz99z5o9dc90keftqhlrz backup]# ll ./mysql
6.擴充套件使用
我們解壓一下已經成功匯出的檔案,看看原檔案大小和壓縮後的檔案大小對比
[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的對比,如果資料庫比較大的話,更能節省空間
到這裡為止,我們的匯出指令碼已經完成了,接下來就是匯入指令碼了
第二:資料庫通過備份恢復
1.建立指令碼檔案
按照第一步的操作,此時我們應該處於 /data/backup 目錄下,繼續操作
[root@izwz99z5o9dc90keftqhlrz backup]# vi mysql_restore.sh #!/bin/bash if [ -z $1 ] || [ ! -f $1 ] then echo "請輸入sql壓縮檔案(*.sql.gz)" exit 1 fi #輸入你自己的資料庫名稱 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 '檔案格式不正確,請輸入 .sql.gz 檔案' exit 1 fi sql_file=${gz_sql_file%.*} echo '解壓檔案中...' gzip -dc $base_dir$gz_sql_file > $base_dir$sql_file echo '解壓完成.' echo '開始匯入資料庫...' mysql --defaults-extra-file=/data/backup/my_mysql.cnf $db_name < $base_dir$sql_file if [ -f $base_dir$sql_file ] then echo '刪除臨時檔案.' rm -f $base_dir$sql_file fi echo '匯入完成.'
上面程式碼中的配置檔案,就是我們第一步時建立的配置檔案,在這裡一樣的使用
2.增加檔案可執行許可權
[root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_restore.sh
3.我們來執行通過備份檔案恢復資料庫
[root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_restore.sh ./mysql/2019-12-22_180359.sql.gz
解壓檔案中...
解壓完成.
開始匯入資料庫...
刪除臨時檔案.
匯入完成.
在這裡我們的第一個引數可以直接寫備份檔案的名字,不用寫目錄,但是因為加上目錄之後,可以使用table進行自動補全,所以十分方便,其他的執行方式:其實懂的人知道都一樣
其實可以在任何資料夾進行恢復,執行 這個可以在任意位置執行
[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
第三:資料庫備份自動化
1.新增計劃任務
[root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e # 貼上下面的內容, 資料庫自動備份 0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1點,中午12點備份一次資料
第四:清理過期備份檔案
1.建立刪除檔案指令碼
[root@izwz99z5o9dc90keftqhlrz mysql]# vi remove_backup.sh #/bin/bash # 刪除15天前的備份 find /data/backup/mysql -type f -mtime +15 | xargs rm -f
我這裡是選擇備份資料只保留最近15天的,大家根據需要自行修改
2.新增可執行許可權
[root@izwz99z5o9dc90keftqhlrz mysql]# chmod +x ./remove_backup.sh #手動刪除 15天前的備份 [root@izwz99z5o9dc90keftqhlrz mysql]# ./remove_backup.sh
3.自動清理
[root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e # 下面這個就是指令碼內容哦,新增這一句 0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1點,自動刪除15天[15是remove_backup.sh裡面配置的]前的備份
第五:定時任務配置給貼出來
# 貼上下面的內容, 資料庫自動備份 0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1點,中午12點備份一次資料 # 下面這個就是指令碼內容哦,新增這一句 0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1點,自動刪除15天[15是remove_backup.sh裡面配置的]前的備份
總結
以上所述是小編給大家介紹的CentOS7下 MySQL定時自動備份的實現方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!