Shell-实际业务操作01-CSDN博客

88 阅读1分钟
#!/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

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