日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

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

發布時間:2023/12/4 linux 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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 重定向错误输出到文件 加上时间(标明错误抛出的时间)...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。