在开发中,我们避免不了写crontab脚本来异步执行一些东西,一般设置crontab用下面的方法:
*/1 * * * * commond > /tmp/t.log 2>&1
前面的> /tmp/t.log代表把标准输出重定向到/tmp/t.log文件,后面的 2>&1 代表把标准错误输出指向标准输出,意思是当commond异常退出时,把异常退出时的日志也写到 /tmp/t.log 下面,这时记录的日志是没有时间信息的,就是说日志里的数据没有办法知道是什么时候打印出来的。
下面通过一个shell来解决这件事,代码如下:
#!/bin/sh
if [ $# -gt 1 ];then
date=`date +%Y-%m-%d@%H:%M:%S`
for((i=2;i<=$#;i++))
do
string=$string""${!i}
done
c=$date":"$string
echo "">>$1
echo $c >>$1
fi
把上面的代码保存为 datecrontalog.sh。
附:linux下shell的特殊字符解释
$0 这个程式的执行名字
$n 这个程式的第n个参数值,n=1..9
$* 这个程式的所有参数,此选项参数可超过9个。
$# 这个程式的参数个数
$$ 这个程式的PID(脚本运行的当前进程ID号)
$! 执行上一个背景指令的PID(后台运行的最后一个进程的进程ID号)
$? 执行上一个指令的返回值 (显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误)
$- 显示shell使用的当前选项,与set命令功能相同
$@ 跟$*类似,但是可以当作数组用
然后在crontab -e用下面的脚本代替
*/1 * * * * commond 2>&1 | xargs $HOME/datecrontalog.sh /tmp/t.log
附:| 管道符与xargs的区别
| 管道符是实现“将前面的标准输出作为后面的标准输入”
xargs是实现“将标准输入作为命令的参数”