Shell腳本自動備份MySQL到FTP并定期清理過期備份
以前公司用的一個網(wǎng)上找的MySQL自動備份到FTP的Shell腳本,一直用著不錯。但是問題就是隨著備份文件的越來越多,不得不定期清理FTP上的老備份文件,十分的不便。
實際上MySQL備份無需保留太長時間的,如果能有自動清理舊的備份文件的功能就好了。不過網(wǎng)上找了一下,雖然也有這方面的腳本,不過可能不太符合我的需求吧。于是只能自己手動改下以前的那個Shell腳本來實現(xiàn)咯。
首先我們要確定保留備份的時間,我覺得一個月的備份保留就足夠了。因為基本不會出現(xiàn)1個月后要恢復(fù)1個月之前備份的情況。(如果有請自己手動備份,畢竟自動備份還是不能取代手動備份的部分)。那么我們的思路就出來了:在上傳以當天日期為文件名的備份的時候,順便刪除下一個月之前的同日期備份,就可以確保服務(wù)器上保留的是最近一個月的備份了。
然后我們需要知道Linux下的一個命令:date。這是個可以查看當前服務(wù)器的時間日期信息的命令。當然這里我們需要知道的是這個命令的參數(shù),畢竟我們需要得到的是日期部分。
輸入下面這個命令,可以看到“年-月-日”的輸入,類似“2011-09-09”:
date +%Y-%m-%d
那么,如果我們要得到1個月之前的日期怎么辦呢?使用下面的這條命令就可以得到:
date -d last-month +%Y-%m-%d
怎么樣?簡單吧。實際備份的時候,因為之前腳本使用的是“m-d-Y”的形式,也就是“月-日-年”的形式,所以我稍微做了下調(diào)整。但是下面這個Shell腳本中的是按照“年-月-日”來產(chǎn)生文件名的。
于是,給出整個備份Shell腳本,需要的朋友只需要填寫下有中文說明的部分,即可在自己的Linux服務(wù)器上使用。使用辦法:復(fù)制到某個目錄下,然后給予執(zhí)行權(quán)限,再在cron中設(shè)置每天指定時間運行即可。(關(guān)于這部分,請自行查找相關(guān)說明,這里不再復(fù)述)
帶自動清理功能的MySQL備份到FTP的Shell腳本如下:
#!/bin/bash
MyUSER="db_username" # 數(shù)據(jù)庫用戶名,建議使用root賬戶或者擁有全局權(quán)限的用戶名
MyPASS="db_password" # 數(shù)據(jù)庫密碼
MyHOST="localhost" # 數(shù)據(jù)庫服務(wù)器
# Linux bin paths, change this if it can't be autodetected via which command
MYSQL="$(which mysql)"
MYSQLDUMP="$(which mysqldump)"
CHOWN="$(which chown)"
CHMOD="$(which chmod)"
GZIP="$(which gzip)"
# 數(shù)據(jù)庫備份的路徑
DEST="/home/backup"
# Main directory where backup will be stored
MBD="$DEST/mysql"
# Get hostname
HOST="$(hostname)"
# Get data in dd-mm-yyyy format
NOW="$(date +%d-%m-%Y)"
OLD="$(date -d last-month +%d-%m-%Y)"
# File to store current backup file
FILE=""
# Store list of databases
DBS=""
# DO NOT BACKUP these databases
IGGY="test"
rm -rf $MBD
[ ! -d $MBD ] && mkdir -p $MBD || :
# Only root can access it!
$CHOWN 0.0 -R $DEST
$CHMOD 0600 $DEST
# Get all database list first
DBS="$($MYSQL -u $MyUSER -h $MyHOST -p$MyPASS -Bse 'show databases')"
cat > ftpcc.sh <<EOF
cd $MBD
ftp -i -n<<!
open blog.renhao.org #在這里填寫FTP服務(wù)器的域名或IP
user ftp_user ftp_pass #在這里填寫FTP用戶名和密碼,注意空格分隔
binary
mput *.gz
EOF
for db in $DBS
do
skipdb=-1
if [ "$IGGY" != "" ];
then
for i in $IGGY
do
[ "$db" = "$i" ] && skipdb=1 || :
done
fi
if [ "$skipdb" = "-1" ] ; then
FILE="$MBD/$db.$HOST.$NOW.gz"
echo "delete $db.$HOST.$OLD.gz" >> ftpcc.sh
# do all inone job in pipe,
# connect to mysql using mysqldump for select mysql database
# and pipe it out to gz file in backup dir :)
$MYSQLDUMP -u $MyUSER -h $MyHOST -p$MyPASS $db | $GZIP -9 > $FILE
fi
done
cat >> ftpcc.sh <<EOF
close
bye
!
EOF
sh ftpcc.sh
rm ftpcc.sh
這樣的Shell腳本運行后,可以得到每個MySQL庫的獨立備份文件,且以gz格式壓縮以便節(jié)省空間。
相關(guān)文章
Linux中使用locate和find進行不區(qū)分大小寫的文件搜索
在日常使用計算機的過程中,尤其是處理大量文件時,快速找到特定文件變得尤為重要,Linux系統(tǒng)提供了許多命令行工具,其中“l(fā)ocate”和“find”是兩個常用的文件搜索工具,本文給大家介紹了如何在Linux中使用locate和find進行不區(qū)分大小寫的文件搜索2024-05-05shell腳本學習指南[五](Arnold Robbins & Nelson H
這篇文章主要介紹了shell腳本學習指南[五](Arnold Robbins & Nelson H.F. Beebe著),需要的朋友可以參考下2014-02-02Linux實現(xiàn)定時備份MySQL數(shù)據(jù)庫并刪除30天前的備份文件
這篇文章主要介紹了Linux實現(xiàn)定時備份MySQL數(shù)據(jù)庫并刪除30天前的備份文件,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01Linux下使用Shell腳本實現(xiàn)ftp的自動上傳下載的代碼小結(jié)
如何實現(xiàn)在ftp自動上傳下載文件腳本呢?想必還有很多朋友都不太了解吧,下面是ftp自動上傳下載文件腳本方法,希望對朋友們有些幫助2013-02-02Linux?shell命令行查詢文件中內(nèi)容常用的命令及其用法
在Linux中,查找文件內(nèi)容可以使用多種命令,如grep、find、ack和ripgrep,這些工具各有特點,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-09-09