Shell-实际业务操作01

前端之家收集整理的这篇文章主要介绍了Shell-实际业务操作01前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
#!/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_MENU

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

#循环遍历目录,业务操作
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

      #循环遍历文件
      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
    fi

done 

#结束时间
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.008s
echo "==========================time consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1
#输出一行空行到日志中,方便区分每次执行的日志
echo "" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1

exit $EXIT_SUCCESS
原文链接:https://www.f2er.com/bash/392617.html

猜你在找的Bash相关文章