Shell-实际业务操作02

来源:互联网 发布:装个博卡软件多少钱 编辑:程序博客网 时间:2024/06/05 07:09
#!/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/normalVOICE_GZ_FILE=/bakcdr/cdrbak/VOICE/gz_fileDATA_NORMAL=/bakcdr/cdrbak/DATA/normalDATA_GZ_FILE=/bakcdr/cdrbak/DATA/gz_fileSMS_NORMAL=/bakcdr/cdrbak/SMS/normalSMS_GZ_FILE=/bakcdr/cdrbak/SMS/gz_file#目标话单路径TargetVoicePath=/bakcdr/cdrbak/VOICETargetDataPath=/bakcdr/cdrbak/DATATargetSmsPath=/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_NORMALCheck_TargetMenu $VOICE_GZ_FILECheck_TargetMenu $DATA_NORMALCheck_TargetMenu $DATA_GZ_FILECheck_TargetMenu $SMS_NORMALCheck_TargetMenu $SMS_GZ_FILE#取话单的原始目录  暂不考虑通过外部参数传入SOURCE_MENU='/ocs/data/output_bak0617/251/normal/bak'#检查话单来源目录是否存在,不存在不创建目录,直接退出当前执行的脚本,存在则进入对应的目录Check_SourceMenu $SOURCE_MENUecho "==========================begin  `date "+%Y-%m-%d %H:%M:%S"`===============================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1#在原始话单路径下 提取话单    Check_SourceMenu已经校验并且进入了话单目录,无需重复进入 . 注意:如果ls获取的文件长度超过系统默认的命令缓冲区最大长度会导致错误。不适合目录下文件特别多的情况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            ;;    esacdone#结束时间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.008secho "==========================time   consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1#输出一行空行到日志中,方便区分每次执行的日志echo "" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1exit $EXIT_SUCCESS