国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > Linux Shell > 正文

linux批量備份服務(wù)器配置文件和目錄的腳本

2020-07-27 19:22:22
字體:
供稿:網(wǎng)友

功能:
1. 只在備份機執(zhí)行,遠(yuǎn)程的服務(wù)器只需要允許備份機用root通過密鑰登錄;
2. 在備份機上配置需要備份哪些服務(wù)器,在NEED_BACKUP_SERVERS這個數(shù)組增減;
3. 在備份機上配置需要備份服務(wù)器上哪些文件,在NEED_BACKUP_DETAIL這個數(shù)組增減,如果需要備份某臺服務(wù)器上NEED_BACKUP_DETAIL數(shù)組里定義的某個文件就備份,不存在的文件則自動跳過,例如Web服務(wù)器上沒my.cnf , 也沒有影響;
4. 如果服務(wù)器上產(chǎn)生的新備份和已經(jīng)存在已往備份內(nèi)容一樣則只保留時間較早的備份。因為服務(wù)器的配置文件不是經(jīng)常改動的;
5. 通過修改定義KEEP_BACKUP_NUM為個變量,可以決定遠(yuǎn)程服務(wù)器上保留最近多少份備份,我這里定義的是10份。備份機上保留所有遠(yuǎn)程服務(wù)器的備份。因為配置文件都比較小,不用擔(dān)心磁盤空間占用問題。

用過下列技術(shù):
1. 獲取遠(yuǎn)程服務(wù)器IP,如果某臺服務(wù)器沒有公網(wǎng)IP則使用該服務(wù)器的“主機名_IP.備份年月日_備份時間.tar.gz
2. 通過循環(huán)、判斷,對數(shù)組中的元素重新賦值;

下載之后請留意版本號和更新日志。

復(fù)制代碼 代碼如下:

#!/bin/bash
##################################################################
# Backup_Config_Files_Of_Remote_Servers
# Env: Centos 5.5 x86_64
# Created by Hernan on 2011-04-06
# Copyright 2010 __Chengyongxu.com__. All rights reserved.
#
# Version: 1.4.6
# Revision History
##################################################################

# Local Tmp Dir Of This Script
THIS_SCRIPT_TMP=/tmp/Do_at_remote_server.sh
THIS_SCRIPT_TMP_NAME=`echo $THIS_SCRIPT_TMP|awk -F/ '{print $NF}'`
# Local Backup Dir
LOCAL_BACKUP_DIR=/tmp/IDC_config_backup

# Need Backup Servers And Files List
REMOTE_SERVER_TMP_DIR=/tmp/Backup_server_config_files_tmp
NEED_BACKUP_SERVERS=(/
10.0.0.52
server_a_ip /
server_b_ip /
server_c_ip /
server_d_ip /
chengyongxu.com /
)
NEED_BACKUP_DETAIL=(/
/etc/hosts /
/etc/httpd/conf/*.conf /
/etc/httpd/conf.d/*.conf /
/etc/keepalived/keepalived.conf
/etc/my.cnf /
/etc/postfix /
/root/bin/*sh /
/usr/local/nagios/etc/nagios.cfg /
/usr/local/nagios/etc/objects/*cfg /
/usr/local/nginx/conf /
/usr/local/php/etc/php.ini /
/usr/local/php/etc/php-fpm.conf /
/usr/local/php-fcgi/etc/php.ini /
/usr/local/php-fcgi/etc/php-fpm.conf /
/usr/local/sphinx/etc/*.conf /
/var/spool/cron /
)
KEEP_BACKUP_NUM=10

SSH_PORT=22
SSH_USER=root

##################################################################
#
# Global Functions
#
##################################################################

#========= !!!! Warning ! Don't edit next function !!!! =========#
# Create Script Tmp File
Create_Script (){
cat << EOF > $THIS_SCRIPT_TMP
#!/bin/bash

NEED_BACKUP_DETAIL=(${NEED_BACKUP_DETAIL[*]})

# How many nums the backup needed
BAKNUM=$KEEP_BACKUP_NUM

REMOTE_SERVER_TMP_DIR=$REMOTE_SERVER_TMP_DIR
SERVER_IP=/`/sbin/ifconfig|grep "inet addr"|cut -f 2 -d ":"|cut -f 1 -d " "|grep -vE "^10.|^127|^172.16|^192.168"/`
BACKUP_TIME=/`date +%Y%m%d_%H%M/`

##################################################################
#
# Compress NEED_BACKUP_DETAIL
#
##################################################################
# If IPv4 private address only, use hostname.ip
if [ -z /$SERVER_IP ]
then
    SERVER_IP=/`hostname/`_/`/sbin/ifconfig|grep "inet addr"|cut -f 2 -d ":"|cut -f 1 -d " "|grep -vE "^127"|head -n 1/`
fi

# Create Tpm dir
if [ ! -d /$REMOTE_SERVER_TMP_DIR ]
then
    mkdir -p /$REMOTE_SERVER_TMP_DIR
fi

# Compress
for file in /${NEED_BACKUP_DETAIL[*]}
do
    # When you want to backup the file exists,
    #   assign to an element of the new array
    while [ -e /$file ]
    do
        NEED_BACKUP_DETAIL_EXISTS[/$num]=/$file
        let num++
    break
    done
done
tar zcfpP /$REMOTE_SERVER_TMP_DIR//$SERVER_IP./$BACKUP_TIME.tar.gz /${NEED_BACKUP_DETAIL_EXISTS[*]}

##################################################################
#
# If files are the same,keep one only
#
##################################################################
NEW_BACKUP_ARCHIVE_CONTENT=/`tar tvf /$REMOTE_SERVER_TMP_DIR//$SERVER_IP./$BACKUP_TIME.tar.gz/`
for backfile in /`ls /$REMOTE_SERVER_TMP_DIR | grep tar.gz |grep -v /$SERVER_IP./$BACKUP_TIME/`
do
    OLD_BACKUP_ARCHIVE_CONTENT=/`tar tvf /$REMOTE_SERVER_TMP_DIR//$backfile/`
    while [ "/$NEW_BACKUP_ARCHIVE_CONTENT" = "/$OLD_BACKUP_ARCHIVE_CONTENT" ]
    do
        rm -rvf /$REMOTE_SERVER_TMP_DIR//$SERVER_IP./$BACKUP_TIME.tar.gz 1 >> /$REMOTE_SERVER_TMP_DIR/delete_new.log
    break
    done
done

##################################################################
#
# Keep Some Backup Files Newest
#
##################################################################
count=0
for name in /`ls /$BAKPATH/ |grep -E '[0-9]{6,6}' | sort -r/`
do
  count=/$((count+1))
  if [ /$count -gt /$BAKNUM ] ; then
    echo -n "Cleaning old backup: /$name... "
      if [ "/$BAKPATH//$name" = "/" ] ; then
        echo "No rm -rf /!"
        exit 1
      fi
      rm -rf /$BAKPATH//$name
    echo " Done."
  else
    echo "Keeping old backup: /$name"
  fi
done
exit
EOF
}

Copy_Script_To_Remote (){
for server in ${NEED_BACKUP_SERVERS[*]}
do
ssh -p $SSH_PORT -tt $SSH_USER@$server << EOT
mkdir -p $REMOTE_SERVER_TMP_DIR
exit
EOT
scp -P $SSH_PORT $THIS_SCRIPT_TMP $SSH_USER@$server:$REMOTE_SERVER_TMP_DIR/
done
}

Backup_On_Remote_Then_Copy_Back (){
for server in ${NEED_BACKUP_SERVERS[*]}
do
ssh -p $SSH_PORT -tt $SSH_USER@$server << EOP
chmod o+x $REMOTE_SERVER_TMP_DIR/$THIS_SCRIPT_TMP_NAME
sh $REMOTE_SERVER_TMP_DIR/$THIS_SCRIPT_TMP_NAME
rm -f $REMOTE_SERVER_TMP_DIR/$THIS_SCRIPT_TMP_NAME
exit
EOP
rsync -e "ssh -p $SSH_PORT" $SSH_USER@$server:$REMOTE_SERVER_TMP_DIR/*tar.gz $LOCAL_BACKUP_DIR/
done
}

##################################################################
#
# Main
#
##################################################################
#
Create_Script
Copy_Script_To_Remote
Backup_On_Remote_Then_Copy_Back
rm -rf $THIS_SCRIPT_TMP

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鸡西市| 乡城县| 洱源县| 罗甸县| 攀枝花市| 东乡族自治县| 葵青区| 隆安县| 新丰县| 临沂市| 通榆县| 伊春市| 舟山市| 金阳县| 盈江县| 礼泉县| 三穗县| 白水县| 阳朔县| 罗源县| 揭西县| 顺义区| 洱源县| 鄢陵县| 玉龙| 澄城县| 巧家县| 荥经县| 独山县| 且末县| 乌拉特后旗| 天镇县| 临颍县| 湘西| 柞水县| 株洲市| 包头市| 防城港市| 绿春县| 榆中县| 黄山市|