Shell 脚本不能与 crontab 一起工作
Shell script not working with crontab
我有一个脚本可以扫描名称中带有 "RC" 的所有目录和子目录,并删除所有超过 40 天的目录和子目录,但始终保留最后一个,即使它超过 40 天。
我遇到的问题是,如果我 运行 手动脚本 ./cronJob.sh
它会正常工作。但是当我把它放在 crontab 列表中时,它不会删除目录,而只会在日志中输出两行。
#!/bin/bash
datum=$(date -I)
MOUNTLOG=/var/log/softwareRC/
FIND=/bin/find;
deleteDir(){
echo "-------- START $parent --------" >> $MOUNTLOG/$datum.log
dname=$(/usr/bin/dirname )
temp="${dname%\s.*}"
temp=(${temp[@]})
parent="${temp[0]}"
dirNum="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | wc -l)"
najnovejsi="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | sort | tail -n 1)"
if [ $dirNum -gt 1 ]; then
$FIND "$parent" -path "$najnovejsi" -prune -o -name *RC* -mtime +40 -print -exec rm -r "{}" \; >> $MOUNTLOG/$datum.log
fi;
echo "-------- END $parent --------" >> $MOUNTLOG/$datum.log
}
declare -i skipDir=1
while true
do
oldest=$($FIND -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
# echo najstarejsi $oldest
dironly=$(echo $oldest | cut -d' ' -f 2-)
deleteDir "$dironly"
# echo $skipDir $dironly
/bin/sleep 1
if [ "$dironly" = "$testna" ]; then
break
else
testna=$(echo $oldest | cut -d' ' -f 2-)
let "skipDir++"
fi;
# echo primerjava $testna
done
Crontab 作业
0 2 * * * /mnt/local/TempDrive/Software_RC/.cleanOld.sh
日志输出
[root@SambaServer softwareRC]# cat 2017-03-11.log
-------- START --------
-------- END --------
0 2 * * * sh /mnt/local/TempDrive/Software_RC/cleanOld.sh
并检查文件权限和文件所有者
将此行添加到您的脚本中:
#!/bin/bash
exec > $MOUNTLOG/$datum.log 2>&1
datum=$(date -I)
如果 shell 或执行的命令之一出现错误消息,它将显示在日志文件中。
非常感谢您的帮助,很抱歉回复晚了。我已经弄清楚出了什么问题。
问题出在下一行。我必须输入脚本所在位置的整个路径 运行 from.
之前:
oldest=$($FIND -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
之后:
oldest=$($FIND /mnt/local/TempDrive/Software_RC -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
这是工作代码。
#!/bin/bash
datum=$(date -I)
MOUNTLOG=/var/log/softwareRC/
exec > $MOUNTLOG/$datum.log 2>&1
FIND=/bin/find;
deleteDir(){
echo "-------- START $parent --------" >> $MOUNTLOG/$datum.log
dname=$(/usr/bin/dirname )
temp="${dname%\s.*}"
temp=(${temp[@]})
parent="${temp[0]}"
dirNum="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | wc -l)"
najnovejsi="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | sort | tail -n 1)"
if [ $dirNum -gt 1 ]; then
$FIND "$parent" -path "$najnovejsi" -prune -o -name *RC* -mtime +40 -print -exec rm -r "{}" \; >> $MOUNTLOG/$datum.log
fi;
echo "-------- END $parent --------" >> $MOUNTLOG/$datum.log
}
declare -i skipDir=1
while true
do
oldest=$($FIND /mnt/local/TempDrive/Software_RC -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
dironly=$(echo $oldest | cut -d' ' -f 2-)
deleteDir "$dironly"
/bin/sleep 1
if [ "$dironly" = "$testna" ]; then
break
else
testna=$(echo $oldest | cut -d' ' -f 2-)
let "skipDir++"
fi;
done
我有一个脚本可以扫描名称中带有 "RC" 的所有目录和子目录,并删除所有超过 40 天的目录和子目录,但始终保留最后一个,即使它超过 40 天。
我遇到的问题是,如果我 运行 手动脚本 ./cronJob.sh
它会正常工作。但是当我把它放在 crontab 列表中时,它不会删除目录,而只会在日志中输出两行。
#!/bin/bash
datum=$(date -I)
MOUNTLOG=/var/log/softwareRC/
FIND=/bin/find;
deleteDir(){
echo "-------- START $parent --------" >> $MOUNTLOG/$datum.log
dname=$(/usr/bin/dirname )
temp="${dname%\s.*}"
temp=(${temp[@]})
parent="${temp[0]}"
dirNum="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | wc -l)"
najnovejsi="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | sort | tail -n 1)"
if [ $dirNum -gt 1 ]; then
$FIND "$parent" -path "$najnovejsi" -prune -o -name *RC* -mtime +40 -print -exec rm -r "{}" \; >> $MOUNTLOG/$datum.log
fi;
echo "-------- END $parent --------" >> $MOUNTLOG/$datum.log
}
declare -i skipDir=1
while true
do
oldest=$($FIND -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
# echo najstarejsi $oldest
dironly=$(echo $oldest | cut -d' ' -f 2-)
deleteDir "$dironly"
# echo $skipDir $dironly
/bin/sleep 1
if [ "$dironly" = "$testna" ]; then
break
else
testna=$(echo $oldest | cut -d' ' -f 2-)
let "skipDir++"
fi;
# echo primerjava $testna
done
Crontab 作业
0 2 * * * /mnt/local/TempDrive/Software_RC/.cleanOld.sh
日志输出
[root@SambaServer softwareRC]# cat 2017-03-11.log
-------- START --------
-------- END --------
0 2 * * * sh /mnt/local/TempDrive/Software_RC/cleanOld.sh
并检查文件权限和文件所有者
将此行添加到您的脚本中:
#!/bin/bash exec > $MOUNTLOG/$datum.log 2>&1 datum=$(date -I)
如果 shell 或执行的命令之一出现错误消息,它将显示在日志文件中。
非常感谢您的帮助,很抱歉回复晚了。我已经弄清楚出了什么问题。
问题出在下一行。我必须输入脚本所在位置的整个路径 运行 from.
之前:
oldest=$($FIND -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
之后:
oldest=$($FIND /mnt/local/TempDrive/Software_RC -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
这是工作代码。
#!/bin/bash
datum=$(date -I)
MOUNTLOG=/var/log/softwareRC/
exec > $MOUNTLOG/$datum.log 2>&1
FIND=/bin/find;
deleteDir(){
echo "-------- START $parent --------" >> $MOUNTLOG/$datum.log
dname=$(/usr/bin/dirname )
temp="${dname%\s.*}"
temp=(${temp[@]})
parent="${temp[0]}"
dirNum="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | wc -l)"
najnovejsi="$($FIND $parent -maxdepth 1 -name *RC* -type d -print | sort | tail -n 1)"
if [ $dirNum -gt 1 ]; then
$FIND "$parent" -path "$najnovejsi" -prune -o -name *RC* -mtime +40 -print -exec rm -r "{}" \; >> $MOUNTLOG/$datum.log
fi;
echo "-------- END $parent --------" >> $MOUNTLOG/$datum.log
}
declare -i skipDir=1
while true
do
oldest=$($FIND /mnt/local/TempDrive/Software_RC -type d -name *RC* -mtime +40 -printf '%T+ %p\n' | sort -r | tail -n $skipDir | head -n 1)
dironly=$(echo $oldest | cut -d' ' -f 2-)
deleteDir "$dironly"
/bin/sleep 1
if [ "$dironly" = "$testna" ]; then
break
else
testna=$(echo $oldest | cut -d' ' -f 2-)
let "skipDir++"
fi;
done