Linux系統如何實現數據自動化備份?
相對windows而言,linux上的自動備份相對會複雜一些,但通過USA-IDC技術清晰描述整個過程之後也會變的相當簡單,幾步即可完成操作,以下對每個參數都進行了清晰的解釋,如有不明白之處,可聯繫我們。「#」表示註解,是不執行的
#! /usr/bin/env bash
###-------------------------------###
# User Variables #
###-------------------------------##
backupSrc=/var/www/html:/etc/passwd # 表示要備份文件路徑,不同文件夾用「:」分隔
backupDest=/backup # 這個參數不用去更改
removePrevious=y # 伺服器上是否需要保存本備文件 #default remove previous
DATENAME=`date +%Y%m%d%H%M` # 根據不同日期產生不同名稱備份文件
tmpPath=/backup/tmp$DATENAME # 臨時文件路徑,不用更改
mkdir -p /backup/tmp$DATENAME # 臨時文件路徑,不用更改
### 配置 FTP ###
useFTP=y # 是否需要備份到遠程FTP上 # y or n
user=xxxxx # FTP帳號
password=xxxxxx # FTP密碼
serverAndPath=ip/123123/ # FTP伺服器和路徑, # default put server root path
ftpServer=ftp://$user:$password@$serverAndPath # 參數不用改
# Syntax for ftpserver:
(WITHOUT Trailing /) 不用管;
### 配置資料庫Mysql ###
mysqlFlag=y # 是否需要備份資料庫 # default backup database
mysqlUser=xxxxx # 資料庫備份帳號
mysqlPassword=xxxxxxxxxxxxx #資料庫備份密碼
argv=" --all-databases --event" # 資料庫備份參數
if [ removePrevious = y ]
then
cd /backup
rm -rf *.tar.gz
fi
### Begin Backup Script ###
backupFile()
{
Path=`echo $1 | sed s#//*$##`
backupPath=${Path%/*}
backupName=${Path##/*/}
if [ -d $Path ] ; then
cd $backupPath
tar czvf $tmpPath/$backupName.tar.gz $backupName > /dev/null 2>&1
fi
if [ -f $Path ] ; then
tar czvf $tmpPath/$backupName.tar.gz $Path > /dev/null 2>&1
fi
}
backMysql()
{
cd $tmpPath
mysqldump -u$mysqlUser -p$mysqlPassword $argv> sql.bak
}
## backup file or dir ###
oldIFS=$IFS
IFS=:
for file in $backupSrc
do
backupFile $file
done
IFS=$oldIFS
## backup file end ###
## backup myql ###
if [ $mysqlFlag = y ]
then
backMysql
fi
## backup myql ###
## create backupfile begin ###
cd /backup
tar czvf $DATENAME.tar.gz $tmpPath/* > /dev/null 2>&1
rm -rf $tmpPath
## create backupfile end ###
if [ $useFTP = y ]
then
echo "$DATENAME.tar.gz $ftpServer"
curl -T $DATENAME.tar.gz $ftpServer
fi
推薦閱讀: