Shell-实际业务操作01

来源:互联网 发布:装个博卡软件多少钱 编辑:程序博客网 时间:2024/05/16 03:46
#!/bin/sh################################ 名称: MvOtherCdrTo251.sh## 描述: /ocs/data/output目录下的25开头(251,257,258除外)对应目录下的/normal/bak下的文件 全部转移到/ocs/data/output/251/normal/bak## 参数: 暂无## 作者: 小工匠## 日期: 2017-06-17## 版本:V1.0## 备注:使用时注意修改TARGET_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#判断目录是否存在,存在则进入$1所在的目录,不存在不创建目录,直接退出Check_TargetMenu(){    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/MvOtherCdrTo251.log 2>&1        exit $EXIT_FAILURE    else        cd $1        echo Current Directory $1    fi}#定义脚本执行取话单的目录  暂不考虑外部传参TARGET_MENU='/ocs/data/output_bak0617'#检查目录是否存在,不存在暂不创建目录,直接退出当前执行的脚本,存在进入对应的目录Check_TargetMenu $TARGET_MENUecho "==========================begin  `date "+%Y-%m-%d %H:%M:%S"`===============================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1#循环遍历目录,业务操作#注意:如果ls获取的文件长度超过系统默认的命令缓冲区最大长度会导致错误。不适合目录下文件特别多的情况 .#可以改用 find . -name "in*.s" | xargs ls 'in*.s' for operatingDir in `ls -d 25*` do    #如果不是251、257、258目录,则进行mv操作    if [ $operatingDir != '251' ]&&[ $operatingDir != '257' ]&&[ $operatingDir != '258' ]; then         echo $operatingDir        #获取该目录绝对路径      Current_oper_dir=$(cd $TARGET_MENU/$operatingDir && pwd)      echo Current_oper_dir $Current_oper_dir      #检验目录是否存在,不存在,不创建,直接退出      Dir_Normal_bak=$Current_oper_dir/normal/bak      Check_TargetMenu $Dir_Normal_bak      #转移文件的目标目录      Final_Menu=$TARGET_MENU/251/normal/bak      #循环遍历文件,注意:如果ls获取的文件长度超过系统默认的命令缓冲区最大长度会导致错误。不适合目录下文件特别多的情况      for file in `ls in*.s`      do        mv $file $Final_Menu        echo "$file  moved to $Final_Menu successfully " >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1      done    fidone #结束时间END_TIME=$(date +%s)echo "==========================end    `date "+%Y-%m-%d %H:%M:%S"`=================================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1#计算脚本执行时间#也可以 通过下面的方式统计  time  脚本名称#....省略执行过程#real   0m2.024s#user   0m0.007s#sys    0m0.008secho "==========================time   consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1#输出一行空行到日志中,方便区分每次执行的日志echo "" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1exit $EXIT_SUCCESS
原创粉丝点击