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 重定向错误输出到文件 加上时间(标明错误抛出的时间)...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux浏览器不能播放音频文件夹,在h
- 下一篇: e2200网卡驱动 linux,Linu