2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > linux重定向输出时加时间变量 shell 重定向错误输出到文件 加上时间(标明错误抛出

linux重定向输出时加时间变量 shell 重定向错误输出到文件 加上时间(标明错误抛出

时间:2023-03-23 04:03:51

相关推荐

linux重定向输出时加时间变量 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是实现“将标准输入作为命令的参数”

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。