linux重定向输出时加时间变量,shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)...
在開發(fā)中,我們避免不了寫crontab腳本來異步執(zhí)行一些東西,一般設(shè)置crontab用下面的方法:
*/1 * * * * commond > /tmp/t.log 2>&1
前面的> /tmp/t.log代表把標(biāo)準(zhǔn)輸出重定向到/tmp/t.log文件,后面的 2>&1 代表把標(biāo)準(zhǔn)錯(cuò)誤輸出指向標(biāo)準(zhǔn)輸出,意思是當(dāng)commond異常退出時(shí),把異常退出時(shí)的日志也寫到 /tmp/t.log 下面,這時(shí)記錄的日志是沒有時(shí)間信息的,就是說日志里的數(shù)據(jù)沒有辦法知道是什么時(shí)候打印出來的。
下面通過一個(gè)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 這個(gè)程式的執(zhí)行名字
$n 這個(gè)程式的第n個(gè)參數(shù)值,n=1..9
$* 這個(gè)程式的所有參數(shù),此選項(xiàng)參數(shù)可超過9個(gè)。
$# 這個(gè)程式的參數(shù)個(gè)數(shù)
$$ 這個(gè)程式的PID(腳本運(yùn)行的當(dāng)前進(jìn)程ID號(hào))
$! 執(zhí)行上一個(gè)背景指令的PID(后臺(tái)運(yùn)行的最后一個(gè)進(jìn)程的進(jìn)程ID號(hào))
$? 執(zhí)行上一個(gè)指令的返回值 (顯示最后命令的退出狀態(tài)。0表示沒有錯(cuò)誤,其他任何值表明有錯(cuò)誤)
$- 顯示shell使用的當(dāng)前選項(xiàng),與set命令功能相同
$@ 跟$*類似,但是可以當(dāng)作數(shù)組用
然后在crontab -e用下面的腳本代替
*/1 * * * * commond 2>&1 | xargs $HOME/datecrontalog.sh /tmp/t.log
附:| 管道符與xargs的區(qū)別
| 管道符是實(shí)現(xiàn)“將前面的標(biāo)準(zhǔn)輸出作為后面的標(biāo)準(zhǔn)輸入”
xargs是實(shí)現(xiàn)“將標(biāo)準(zhǔn)輸入作為命令的參數(shù)”
總結(jié)
以上是生活随笔為你收集整理的linux重定向输出时加时间变量,shell 重定向错误输出到文件 加上时间(标明错误抛出的时间)...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux浏览器不能播放音频文件夹,在h
- 下一篇: e2200网卡驱动 linux,Linu