shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)

在开发中,我们避免不了写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是实现“将标准输入作为命令的参数”


你可能感兴趣的:(shell)