Shell-实际业务操作02

前端之家收集整理的这篇文章主要介绍了Shell-实际业务操作02前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
#!/bin/sh
##############################
## 名称: MvCdr4Classify.sh
## 描述: 将/ocs/data/output/251/normal/bak目录下的全部话单按照类别存储到对应的目录下(VOICE\DATA\SMS)
## 规则 001 Data 002 Voice 004 SMS
## 每种话单的目录下,有normal和gz_file两个目录,normal目录存放处理之后的话单,gz目录存放处理之后压缩的话单
## 参数: 暂无
## 作者: 小工匠
## 日期: 2017-06-17
## 版本:V1.0
## 备注:使用时注意修改SOURCE_MENU的值,测试用,取的是bak目录
##############################

#定义退出标识符,脚本执行后,通过echo $? 查看退出标识符,即上个命令或者脚本的返回结果
EXIT_FAILURE=1   #Failing exit status 
EXIT_SUCCESS=0   #Successful exit status 

#开始时间
BEGIN_TIME=`date +%s`

#当前执行脚本的全路径
SCRIPT_PATH=$(cd `dirname $0`; pwd)
SCRIPT_NAME=`basename $0` 

#日志路径
LOG_LOCATION=/ocs/tools/OperCDR/logs

#存放话单目标目录 
#mkdir -p new_folder/{folder_1,folder_2..} 将目录作为参数传入对应的函数 这种快捷的方式,不能有效的判断目录是否存在,暂时采用逐条创建的方式
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

#目标话单路径
TargetVoicePath=/bakcdr/cdrbak/VOICE
TargetDataPath=/bakcdr/cdrbak/DATA
TargetSmsPath=/bakcdr/cdrbak/SMS


#判断话单存放目录是否存在,存在则进入$1所在的目录,不存在不创建目录,直接退出
Check_SourceMenu(){
    if [ ! -d $1 ];then
        echo -e "Target Menu \033[31m$1 does not exist \033[0m,existing the script \033[31m$SCRIPT_PATH/$SCRIPT_NAME\033[0m,check fisrt please" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
        exit $EXIT_FAILURE
    else
        cd $1
        echo Current Directory $1 
    fi
}


#判断存放话单的目标目录是否存,不存在则创建目录
Check_TargetMenu(){
    if [ ! -d $1 ] ; then 
        mkdir -p $1
        echo $1 does not exists,create successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
    fi
}


#处理话单文件
DealCDRFile(){
    #转移到Target对应目录下
    #mv $1 $2
  #echo "$1 moved to $2 successfully " >>$LOG_LOCATION/MvCdr4Classify.log 2>&1

    #提取$1的日期,创建目录
    CDR_DATE=`echo $1 | awk 'BEGIN{FS="_"}{print substr($5,1,8)}'`
    echo $CDR_DATE

    FinalPath=$2/normal/$CDR_DATE
    if [ ! -d $FinalPath ] ; then 
        mkdir -p $FinalPath
    else
        #将话单转移到改目录下
        mv $1  $FinalPath
        echo "$1 moved to $FinalPath successfully " >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
    fi
}


#检查话单存放目录是否存在 不存在则创建
Check_TargetMenu $VOICE_NORMAL
Check_TargetMenu $VOICE_GZ_FILE
Check_TargetMenu $DATA_NORMAL
Check_TargetMenu $DATA_GZ_FILE
Check_TargetMenu $SMS_NORMAL
Check_TargetMenu $SMS_GZ_FILE


#取话单的原始目录 暂不考虑通过外部参数传入
SOURCE_MENU='/ocs/data/output_bak0617/251/normal/bak'

#检查话单来源目录是否存在,不存在不创建目录,直接退出当前执行的脚本,存在则进入对应的目录
Check_SourceMenu $SOURCE_MENU

echo "==========================begin `date "+%Y-%m-%d %H:%M:%S"`===============================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1


#在原始话单路径下 提取话单 Check_SourceMenu已经校验并且进入了话单目录,无需重复进入
for file in `ls in*.s`
do

    #从话单文件名称获取话单标识 001 Data 002 Voice 004 SMS
    CDR_FLAG=`echo $file | awk 'BEGIN{FS="_"}{print $3}'`
    #分支判断
    case $CDR_FLAG in 
        001) 
            DealCDRFile $file $TargetDataPath
            echo Deal Data CDR $CDR_FLAG  Successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
            ;;
        002)
            DealCDRFile $file $TargetVoicePath
            echo Deal Voice CDR  $CDR_FLAG  Successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
            ;;
        004)
            DealCDRFile $file $TargetSmsPath
            echo Deal SMS  CDR $CDR_FLAG  Successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
            ;;
        *)
            ##匹配不到的文件,红色输出到日志, ERROR关键字
            echo -e "\033[31m ERROR $file CDR_FLAG not in 001 002 004 \033[0m"  >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
            ;;
    esac

done
#结束时间
END_TIME=$(date +%s)
echo "==========================end `date "+%Y-%m-%d %H:%M:%S"`=================================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1

#计算脚本执行时间

#也可以 通过下面的方式统计 time 脚本名称
#....省略执行过程
#real 0m2.024s
#user 0m0.007s
#sys 0m0.008s
echo "==========================time consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
#输出一行空行到日志中,方便区分每次执行的日志
echo "" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1

exit $EXIT_SUCCESS

猜你在找的Bash相关文章