我还在学习Bash,我的脚本有问题。我想用这个分析呼叫日志的脚本过滤一些调用,每2分钟作为cronjob。问题是我可以手动运行它但是从cron自动运行时它会失败。我不知道为什么。它大肆宣传权限,所以我有点修补了脚本,所以如果它看起来很脏我很抱歉。
#!/bin/bash
YESTERDAY=$((`date +'%s'`-86400))
AYER=`date -d "1970-01-01 $YESTERDAY sec" +"%Y%m%d"`
FECHA=`date +"%Y%m%d"`
FILENAME="$FECHA.log"
FILE_LINE="$FECHA.last"
FILE="/apps/sittel/rawdata/mitel.$FECHA"
# Limpiar carpeta tmp
if [ -e "tmp/$AYER.lnum" ]; then
rm tmp/${AYER}.*
fi
# Si existe el archivo con el numero de laultima linea se procesa
if [ -e "tmp/$FECHA.lnum" ]; then
# Se lee el numero de la linea y se extrae un archivo con las lineas apartir
# de la ultima busqueda que se hizo, posteriormente se les hace un grep
while read line
do
tail -n +$line $FILE > "tmp/$FECHA.hal"
done < "tmp/$FECHA.lnum"
cd tmp
grep -n " 00[0|2-9][0-9]\{4,\}" "tmp/$FECHA.hal" > "tmp/${FECHA}.new"
grep -n " 900[0|2-9][0-9]\{4,\}" "tmp/$FECHA.hal" >> "tmp/${FECHA}.new"
cd ..
echo `pwd`
cat tmp/${FECHA}.new >> logs/$FILENAME
else
# Este caso es la primera vez que se ejecuta, verifica si el log ya existe
# de ser asi, lo elimina para evitar duplicados
if [ -e "logs/$FILENAME" ]; then
rm "logs/$FILENAME"
fi
# Se realiza un grep en el archivo indicado y se marca el archivo de salida
# se busca todos los numeros k empiecen con 00 seguidos de 0 a 9 execpto el 1
cd tmp
grep -n " 00[0|2-9][0-9]\{4,\}" $FILE>"${FECHA}.new"
grep -n " 900[0|2-9][0-9]\{4,\}" $FILE>>"${FECHA}.new"
cat ${FECHA}.new >> $FILENAME
mv $FILENAME ../logs
cd ..
fi
cp "tmp/${FECHA}.new" "tmp/message.txt"
echo "Mensaje" | mail -s "$SUBJECT" "$EMAIL" < "tmp/message.txt"
fi
if [ -e "tmp/${FECHA}.new" ]; then
rm "tmp/${FECHA}.new"
fi
tail -n1 "logs/$FILENAME" > "tmp/$FILE_LINE"
IFS=$':'
while read line
do
DATOS=($line)
LINE_NUMBER=${DATOS[0]}
echo $LINE_NUMBER > "tmp/$FECHA.lnum"
done < "tmp/$FILE_LINE"
unset IFS
这就是系统打印的内容:
/apps/sittel/Alarma/callAlarm: line 56: cd: tmp: No such file or directory
mv: cannot move `20110712.log' to `../logs': Permission denied
/apps/sittel/Alarma/callAlarm: line 69: tmp/20110712.last: No such file or directory
/apps/sittel/Alarma/callAlarm: line 77: tmp/20110712.last: No such file or directory
答案 0 :(得分:2)
您的脚本假定它是从特定目录运行的(请注意,几乎每个路径都是相对路径,而不是绝对路径)。 cron
恰好是从另一个目录运行它。
如果脚本从您所在的目录运行时起作用,请将以下内容添加到脚本的顶部:
mydir=$(dirname "$0") && cd "${mydir}" || exit 1
$0
是正在执行的shell脚本的(可能是相对的)文件名。给定文件名,dirname
命令返回包含文件名的目录。
因此,该行将目录更改为包含脚本的目录,如果dirname
或cd
失败,则退出时会显示错误代码。
答案 1 :(得分:0)
看起来您可能需要cd
进入脚本开头的正确目录。
在开头放置一个pwd
,然后是exit
并观察cron输出以查看您正在执行的位置。在cron下运行时,您有可能缩短PATH
,但它仍然可以访问tail
和grep
。
答案 2 :(得分:0)
您似乎正在假设某个起始目录,并在那里创建一个tmp
目录。但是当你将它作为一个cron作业运行时,它会从一个不同的地方开始。因此,bash启动脚本中的CD命令可能会让您感到困惑。您可以在cd
或rm
或其他时使用完整路径名轻松进行测试。
例如,
if [ -e "tmp/$AYER.lnum" ]; then
rm /home/username/tmp/${AYER}.*
fi
# Si existe el archivo con el numero de laultima linea se procesa
if [ -e "/home/username/tmp/$FECHA.lnum" ]; then
# Se lee el numero de la linea y se extrae un archivo con las lineas apartir
# de la ultima busqueda que se hizo, posteriormente se les hace un grep
while read line
do
tail -n +$line $FILE > "/home/username/tmp/$FECHA.hal"
done < "/home/username/tmp/$FECHA.lnum"
cd /home/username/tmp
grep -n " 00[0|2-9][0-9]\{4,\}" "/home/username/tmp/$FECHA.hal" > "/home/username/tmp/${FECHA}.new"
等等。