Linux系統如何實現數據自動化備份?

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

推薦閱讀:

TAG:Linux | Linux安裝 | Ubuntu |