在Centos7中利用Shell腳本實(shí)現(xiàn)MySQL數(shù)據(jù)備份
前言:
備份是容災(zāi)的基礎(chǔ),是指為防止系統(tǒng)出現(xiàn)操作失誤或系統(tǒng)故障導(dǎo)致數(shù)據(jù)丟失,而將全部或部分?jǐn)?shù)據(jù)集合從應(yīng)用主機(jī)的硬盤或陣列復(fù)制到其它的存儲介質(zhì)的過程。而對于一些網(wǎng)站、系統(tǒng)來說,數(shù)據(jù)庫就是一切,所以做好數(shù)據(jù)庫的備份是至關(guān)重要的 !
自動化備份MySQL
一.備份數(shù)據(jù)庫腳本
1.創(chuàng)建備份目錄
盡量選擇空間比較充足的目錄,這里以/home目錄為例保存?zhèn)浞菸募贿M(jìn)入到/home目錄下,創(chuàng)建backup目錄,并進(jìn)入到新建的backup目錄下
cd /home mkdir backup cd backup
2.創(chuàng)建腳本文件
創(chuàng)建mysql_backup.sh
數(shù)據(jù)庫備份腳本 #!/bin/bash # db_name 自己改這里哦 db_name='mybatis_ssm' backup_dir='/home/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ù)庫...' mysqldump --defaults-extra-file=/home/backup/my_mysql.cnf $db_name --net-buffer-length=10m | gzip > $filepath echo '導(dǎo)出成功,文件名為: '$filepath
在其中需要修改是:db_name,backup_dir以及mysqldump的存放路徑
3.新建配置文件(連接數(shù)據(jù)庫的配置文件)
就在我們的當(dāng)前目錄下 即 /data/backup vi my_mysql.cnf
[mysqldump] max_allowed_packet = 400M host=127.0.0.1 user=root password='123' [mysql] host=127.0.0.1 user=root password='123'
在其中需要修改是:host,pwssword
各位看官請把上面的參數(shù)改成自己的就好了,可別漏了這一步哦
其中 mysqldump 下的參數(shù)是給導(dǎo)出的命令使用的,mysql 下的參數(shù)是導(dǎo)入的時候使用的
4.給文件權(quán)限(mysql_backup.sh)
到這里的話導(dǎo)出的shell腳本就已經(jīng)寫好了,我們對這個腳本加一下可執(zhí)行權(quán)限
chmod +x ./mysql_backup.sh
授權(quán)成功的展示
5.執(zhí)行命令 (mysql_backup.sh)
沒有使用命令時用于存儲sql備份的文件夾沒有辦法數(shù)據(jù)腳本
./mysql_backup.sh
通過以下命令進(jìn)行查看是否對應(yīng)的數(shù)據(jù)庫腳本備份成功
cd sql/ ls
在解壓查看備份的數(shù)據(jù)庫文件是否存在數(shù)據(jù)
gzip -d 2023-12-26_090817.sql.gz
二.數(shù)據(jù)庫通過備份恢復(fù)
模擬數(shù)據(jù)庫被刪除,或者因為一些其他原因?qū)е聰?shù)據(jù)庫數(shù)據(jù)丟失導(dǎo)致程序無法正常運(yùn)行
1.創(chuàng)建腳本文件
按照第一步的操作,此時我們應(yīng)該處于 /data/backup 目錄下,繼續(xù)操作
vi mysql_restore.sh
#!/bin/bash if [ -z $1 ] || [ ! -f $1 ] then echo "請輸入sql壓縮文件(*.sql.gz)" exit 1 fi #輸入你自己的數(shù)據(jù)庫名稱 db_name='mybatis_ssm' base_dir='/home/backup/sql/' 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 '開始導(dǎo)入數(shù)據(jù)庫...' mysql --defaults-extra-file=/home/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 '導(dǎo)入完成.'
上面代碼中的配置文件,就是我們第一步時創(chuàng)建的配置文件,在這里一樣的使用
2.增加文件可執(zhí)行權(quán)限(vi mysql_restore.sh)
chmod +x ./mysql_restore.sh
授權(quán)成功的展示
3.我們來執(zhí)行通過備份文件恢復(fù)數(shù)據(jù)庫
沒有備份前
./mysql_restore.sh ./sql/2023-12-26_091800.sql.gz
備份后
執(zhí)行完命令之后在查看數(shù)據(jù)庫
具體思路
三.數(shù)據(jù)庫備份自動化
Cron安裝 這篇博客教你安裝Cron
添加計劃任務(wù) crontab -e
* * * * * /home/backup/mysql_backup.sh #設(shè)置一分鐘備份一個
0 1,12 */7 * * /home/backup/mysql_backup.sh #設(shè)置7天備份一次
小編推薦第三個
0 1,12 * * * /home/backup/mysql_backup.sh # 每天凌晨1點(diǎn),中午12點(diǎn)備份一次數(shù)據(jù)
要編輯或查看 Cron 任務(wù),可以使用以下命令:
crontab -e
:編輯當(dāng)前用戶的 Cron 任務(wù)crontab -l
:查看當(dāng)前用戶的 Cron 任務(wù)列表crontab -r
:移除當(dāng)前用戶的所有 Cron 任務(wù)
代表設(shè)置自動備份成功
四:清理過期備份文件
創(chuàng)建刪除文件腳本 vi remove_backup.sh
刪除過期腳本 #/bin/bash # 刪除15天前的備份 find /home/backup/sql -type f -mtime +15 | xargs rm -f
添加可執(zhí)行權(quán)限
chmod +x ./remove_backup.sh
定時任務(wù)配置給貼出來
0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1點(diǎn),自動刪除15天[15是remove_backup.sh里面配置的]前的備份
五.感謝各位看官的觀看!
以上就是在Centos7中利用Shell腳本實(shí)現(xiàn)MySQL數(shù)據(jù)備份的詳細(xì)內(nèi)容,更多關(guān)于利用Shell腳本實(shí)現(xiàn)MySQL備份的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
一文搞清楚MySQL count(*)、count(1)、count(col)區(qū)別
本文主要介紹了MySQL count(*)、count(1)、count(col)區(qū)別,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03mysql中復(fù)制表結(jié)構(gòu)的方法小結(jié)
這篇文章主要介紹了mysql中復(fù)制表結(jié)構(gòu)的方法,需要的朋友可以參考下2014-07-07MySQL查詢表中重復(fù)數(shù)據(jù)的實(shí)現(xiàn)
在數(shù)據(jù)庫中,我們經(jīng)常需要查詢重復(fù)字段來確保數(shù)據(jù)的準(zhǔn)確性,如果數(shù)據(jù)中有重復(fù)字段,則可能會導(dǎo)致查詢結(jié)果錯誤,本文就想詳細(xì)的介紹了MySQL查詢表中重復(fù)數(shù)據(jù),感興趣的可以了解一下2023-08-08MySQL數(shù)據(jù)庫自動補(bǔ)全命令的三種方法
這篇文章主要介紹了MySQL數(shù)據(jù)庫自動補(bǔ)全命令的三種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02MySQL合并查詢結(jié)果的實(shí)現(xiàn)
本文主要介紹了MySQL合并查詢結(jié)果的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03