亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

CentOS7下 MySQL定時自動備份的實現方法

 更新時間:2019年12月23日 09:28:33   作者:悟能的師兄  
這篇文章主要介紹了CentOS7 下MySQL定時自動備份的實現方法,主要實現了數據庫備份,清理過期備份文件功能,需要的朋友可以參考下

生產環(huán)境遇到得最幸福得事情就是,某些場景沒辦法避免去update或者delete的時候,某個參數沒有注意。完蛋了 完蛋了,數據被我搞崩了怎么辦,趕緊去運營找備份呀!運營說:狗屁 咱們系統(tǒng)從來不備份,你說:那把日志給我吧,運營說:狗屁 每天上G的日志,我都沒給你開,你說:怎么辦,數據庫被我搞崩了。運營說:那是你的事,跟我沒關系........這是某公司的一段寫照,所以今天我們來把這個情況給杜絕

今天要給客戶部署一套系統(tǒng),使用的MySQL5.7,那客戶那邊的開發(fā)人員我可不敢保證他們的能力咋樣。我只能給他們全部開機自啟、數據庫等重要文件自動備份好,一旦出什么幺蛾子。咱風淡云輕的一行命令給搞定,這是一個負責任的做法。準備開始:

我們需要實現下面的幾個功能:

第一:數據庫備份

第二:數據庫通過備份恢復

第三:數據庫備份自動化

第四:清理過期備份文件

第一:數據庫自動備份

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, 已經寫入到配置文件中
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腳本就已經寫好了,我們對這個腳本加一下可執(zhí)行權限

[root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_backup.sh

5.執(zhí)行一下我們的命令

[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的對比,如果數據庫比較大的話,更能節(jié)省空間

到這里為止,我們的導出腳本已經完成了,接下來就是導入腳本了

第二:數據庫通過備份恢復

1.創(chuàng)建腳本文件

按照第一步的操作,此時我們應該處于 /data/backup 目錄下,繼續(xù)操作

[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 '導入完成.'

上面代碼中的配置文件,就是我們第一步時創(chuàng)建的配置文件,在這里一樣的使用

2.增加文件可執(zhí)行權限

[root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_restore.sh

3.我們來執(zhí)行通過備份文件恢復數據庫

[root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_restore.sh ./mysql/2019-12-22_180359.sql.gz

解壓文件中...
解壓完成.
開始導入數據庫...
刪除臨時文件.
導入完成.

在這里我們的第一個參數可以直接寫備份文件的名字,不用寫目錄,但是因為加上目錄之后,可以使用table進行自動補全,所以十分方便,其他的執(zhí)行方式:其實懂的人知道都一樣

其實可以在任何文件夾進行恢復,執(zhí)行 這個可以在任意位置執(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

第三:數據庫備份自動化

1.添加計劃任務

[root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e
 
# 粘貼下面的內容, 數據庫自動備份
0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1點,中午12點備份一次數據

第四:清理過期備份文件

1.創(chuàng)建刪除文件腳本

[root@izwz99z5o9dc90keftqhlrz mysql]# vi remove_backup.sh
#/bin/bash 
# 刪除15天前的備份
find /data/backup/mysql -type f -mtime +15 | xargs rm -f

我這里是選擇備份數據只保留最近15天的,大家根據需要自行修改

2.添加可執(zhí)行權限

[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定時自動備份的實現方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • MySQL深分頁問題原理與三種解決方案

    MySQL深分頁問題原理與三種解決方案

    本文主要介紹了MySql深分頁問題原理與解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • Mysql錯誤:Too many connections的解決方法

    Mysql錯誤:Too many connections的解決方法

    這篇文章主要給大家介紹了關于Mysql錯誤Too many connections的解決方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Mysql具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • MySQL報1366錯誤的原因及解決

    MySQL報1366錯誤的原因及解決

    SQL Error1366是一個常見的 MySQL 錯誤,主要成因是數據類型不匹配或數據超出了范圍,本文主要介紹了MySQL報1366錯誤的原因及解決,感興趣的可以了解一下
    2024-02-02
  • mysql 5.6.13 免安裝版配置方法詳解

    mysql 5.6.13 免安裝版配置方法詳解

    這篇文章主要介紹了mysql 5.6.13 免安裝版配置的方法,今天小編把配置方法分享到腳本之家平臺供大家參考下
    2016-10-10
  • 深入解析MySQL中的longtext與longblob及應用場景

    深入解析MySQL中的longtext與longblob及應用場景

    MySQL作為廣泛應用的關系型數據庫管理系統(tǒng),提供了豐富的數據類型以滿足各種數據存儲需求,本文將深入探討MySQL中l(wèi)ongtext和longblob的特性、區(qū)別以及在實際項目中的應用場景,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • MySQL中的數據類型binary和varbinary詳解

    MySQL中的數據類型binary和varbinary詳解

    binary和varbinary與char和varchar類型有點類似,不同的是binary和varbinary存儲的是二進制的字符串,而非字符型字符串。下面這篇文章主要給大家介紹了關于MySQL中數據類型binary和varbinary的相關資料,介紹的非常詳細,需要的朋友可以參考學習。
    2017-07-07
  • 借助PHP的mysql_query()函數來創(chuàng)建MySQL數據庫的教程

    借助PHP的mysql_query()函數來創(chuàng)建MySQL數據庫的教程

    這篇文章主要介紹了借助PHP的mysql_query()函數來創(chuàng)建MySQL數據庫的教程,將函數配合CREATE DATABASE語句使用,需要的朋友可以參考下
    2015-12-12
  • MySQL每晚定時彈出一個taskeng.exe的解決方法

    MySQL每晚定時彈出一個taskeng.exe的解決方法

    這篇文章主要介紹了MySQL每晚定時彈出一個taskeng.exe的解決方法,需要的朋友可以參考下
    2018-07-07
  • MySQL服務無法啟動且服務沒有報告任何錯誤的解決辦法

    MySQL服務無法啟動且服務沒有報告任何錯誤的解決辦法

    在啟動項目時,發(fā)現昨天能夠跑的項目今天跑不了了,一看原來是mysql數據庫出現了問題,下面這篇文章主要給大家介紹了關于MySQL服務無法啟動且服務沒有報告任何錯誤的解決辦法,需要的朋友可以參考下
    2023-05-05
  • MySQL中查詢字段為空或者為null的方法

    MySQL中查詢字段為空或者為null的方法

    這篇文章主要介紹了MySQL中查詢字段為空或者為null的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論