文章目录
#!/bin/sh
EXIT_FAILURE=1
EXIT_SUCCESS=0
BEGIN_TIME=`date +%s`
CDR_TODAY=`date "+%Y%m%d"`
SCRIPT_PATH=$(cd `dirname $0`; pwd)
SCRIPT_NAME=`basename $0`
LOG_LOCATION=/ocs/tools/OperCDR/logs
CDR_HOST=`hostname | awk 'BEGIN{FS="_"}{print substr($2,1,4)}'|tr '[a-z]' '[A-Z]'`
DATA_FLAG=_DATA_
VOICE_FLAG=_VOICE_
SMS_FLAG=_SMS_
STORED_DIR_DATA=/bakcdr/cdrbak/TARGED_MENU/DATA
STORED_DIR_VOICE=/bakcdr/cdrbak/TARGED_MENU/VOICE
STORED_DIR_SMS=/bakcdr/cdrbak/TARGED_MENU/SMS
VOICE_NORMAL=/bakcdr/cdrbak/VOICE/normal
VOICE_GZ_FILE=/bakcdr/cdrbak/VOICE/gz_file
DATA_NORMAL=/bakcdr/cdrbak/DATA/normal
DATA_GZ_FILE=/bakcdr/cdrbak/DATA/gz_file
SMS_NORMAL=/bakcdr/cdrbak/SMS/normal
SMS_GZ_FILE=/bakcdr/cdrbak/SMS/gz_file
HOST="172.25.243.152"
USER="cdr"
PASSWD="cdr"
REMOTE_DATA_PATH=/backup_storage/bakcdr_ocs/DATA
REMOTE_VOICE_PATH=/backup_storage/bakcdr_ocs/VOICE
REMOTE_SMS_PATH=/backup_storage/bakcdr_ocs/SMS
Check_TargetMenu(){
if [ ! -d $1 ] ; then
mkdir -p $1
echo $1 does not exists , create successfully >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
fi
}
TarCDRMenu2GZ(){
if [ -d $1 ] ; then
cd $1
for dateMenu in `ls`
do
echo 目录名称 $dateMenu
if [ -d $1/$dateMenu ] ; then
if [ $dateMenu -lt $CDR_TODAY ] ; then
if [[ $1 =~ "DATA" ]] ; then
tar -zcvf $CDR_HOST$DATA_FLAG$dateMenu.tar.gz $dateMenu
TARED_GZ_FIEL=$CDR_HOST$DATA_FLAG$dateMenu.tar.gz
elif [[ $1 =~ "VOICE" ]] ; then
tar -zcvf $CDR_HOST$VOICE_FLAG$dateMenu.tar.gz $dateMenu
TARED_GZ_FIEL=$CDR_HOST$VOICE_FLAG$dateMenu.tar.gz
else
tar -zcvf $CDR_HOST$SMS_FLAG$dateMenu.tar.gz $dateMenu
TARED_GZ_FIEL=$CDR_HOST$SMS_FLAG$dateMenu.tar.gz
fi
if [ $? == 0 ] ; then
echo "$1/$dateMenu.tar.gz tared successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
mv $TARED_GZ_FIEL $2
echo "$TARED_GZ_FIEL moved to $2 successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
TaredFileMenu=$1/$dateMenu
Check_TargetMenu $STORED_DIR_DATA
Check_TargetMenu $STORED_DIR_VOICE
Check_TargetMenu $STORED_DIR_SMS
DealTaredFileMenu $TaredFileMenu
fi
fi
else
echo -e "\033[31m ERROR $1/$dateMenu is not a directory \033[0m" >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
fi
done
else
echo -e "\033[31m ERROR $1 does not exist \033[0m" >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
fi
}
DealTaredFileMenu(){
if [[ $1 =~ "DATA" ]] ; then
mv $1 $STORED_DIR_DATA
echo "$1 moved to $STORED_DIR_DATA successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
elif [[ $1 =~ "VOICE" ]] ; then
mv $1 $STORED_DIR_VOICE
echo "$1 moved to $STORED_DIR_VOICE successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
else
mv $1 $STORED_DIR_SMS
echo "$1 moved to $STORED_DIR_SMS successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
fi
}
FtpFile(){
echo FtpFile $1 >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
for file in `ls $1`
do
if [[ $1 =~ "DATA" ]] ; then
PutDataFileByFtp $1 $file
echo "$1/$file put to remote server $HOST $REMOTE_DATA_PATH successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
elif [[ $1 =~ "VOICE" ]] ; then
PutVoiceFileByFtp $1 $file
echo "$1/$file put to remote server $HOST $REMOTE_VOICE_PATH successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
else
PutSmsFileByFtp $1 $file
echo "$1/$file put to remote server $HOST $REMOTE_SMS_PATH successfully " >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
fi
done
}
PutDataFileByFtp(){
ftp -i -n $HOST <<EOF
quote USER $USER
quote PASS $PASSWD
cd $REMOTE_DATA_PATH
put $1/$2 $2
quit
EOF
}
PutVoiceFileByFtp(){
ftp -i -n -d $HOST <<EOF
quote USER $USER
quote PASS $PASSWD
cd $REMOTE_VOICE_PATH
put $1/$2 $2
quit
EOF
}
PutSmsFileByFtp(){
ftp -i -n -d $HOST <<EOF
quote USER $USER
quote PASS $PASSWD
cd $REMOTE_SMS_PATH
put $1/$2 $2
quit
EOF
}
echo "==========================begin `date "+%Y-%m-%d %H:%M:%S"`===============================================" >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
TarCDRMenu2GZ $DATA_NORMAL $DATA_GZ_FILE
TarCDRMenu2GZ $VOICE_NORMAL $VOICE_GZ_FILE
TarCDRMenu2GZ $SMS_NORMAL $SMS_GZ_FILE
FtpFile $DATA_GZ_FILE
FtpFile $SMS_GZ_FILE
FtpFile $VOICE_GZ_FILE
END_TIME=$(date +%s)
echo "==========================end `date "+%Y-%m-%d %H:%M:%S"`=================================================" >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
echo "==========================time consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
echo "" >>$LOG_LOCATION/TarCdrAndTransfer.log 2>&1
exit $EXIT_SUCCESS