好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Linux中crontab輸出重定向不生效問題的解決方法

Linux中crontab輸出重定向不生效問題的解決方法

熱門標簽:廣東如何申請400電話 話術外呼系統 i智能電話機器人yeta 燃氣管線地圖標注顏色 寧波400電話辦理對企業的意義 北京人工外呼系統廠家 哈爾濱400電話去哪辦理 西柏坡地圖標注 400電話申請要什么條件

問題

在LINUX中,周期執行的任務一般由cron這個守護進程來處理[ps -ef|grep cron]。cron讀取一個或多個配置文件,這些配置文件中包含了命令行及其調用時間。

cron的配置文件稱為“crontab”,是“cron table”的簡寫。

近期在crontab中添加了一個定時任務,該任務執行之后默認會有正常輸出。為了確保在任務執行過程中的異常信息也可以捕獲,方便問題定位,因此在crontab中我寫了這么一條命令:

01 09 * * * cd /opdir/test/ && ./test.sh &>>test.log

以上命令非常好理解,每天9:01執行test.sh 腳本并且將腳本的標準錯誤輸出、標準輸出全部重定向到文件 test.log中。最終發現腳本是正常執行了,但是test.log 這個日志文件中卻沒有任何內容。

為了解決和解釋這個問題,接下來我們先簡單介紹下linux系統中重定向的問題

概念

Linux系統中:

1: 表示標準輸出(stdout),默認輸出到屏幕

2:表示標準錯誤輸出(stderr),默認輸出到屏幕

在平時我們經常使用如下方法將腳本執行結果重定向:

bash test.sh >test.out //腳本的標準輸出寫入到文件test.out ,標準錯誤輸出直接打印在屏幕 等價于:bash test.sh 1>test.out
bash test.sh >test.out 2>&1 //標準輸出和標準錯誤輸出都寫入到test.out并且不會互相覆蓋,等價于 bash test.sh &>test.out
bash test.sh >test.out 2>test.out //標準輸出和標準錯誤輸出都寫入到test.out,會出現互相覆蓋的問題,正常情況不推薦這樣使用
bash test.sh &>test.out //等價于第二種方法

比較一下以上幾種的效果:

第一種:錯誤輸出在屏幕,正常輸出在文件test.out

root@mengalong:~/opdir/mengalong/t/t# cat test.sh
#!/bin/bash
t
date

root@mengalong:~/opdir/mengalong/t/t# bash test.sh >test.out
test.sh: line 2: t: command not found
root@mengalong:~/opdir/mengalong/t/t# cat test.out
Wed Oct 31 11:07:24 CST 2018

第二種:錯誤輸出和正常輸出均重定向到文件test.out中

root@mengalong:~/opdir/mengalong/t/t# bash test.sh >test.out 2>&1
root@mengalong:~/opdir/mengalong/t/t# cat test.out
test.sh: line 2: t: command not found
Wed Oct 31 11:09:02 CST 2018

第三種:錯誤輸出和正常輸出互相覆蓋

root@mengalong:~/opdir/mengalong/t/t# bash test.sh >test.out 2>test.out
root@mengalong:~/opdir/mengalong/t/t# cat test.out
Wed Oct 31 11:10:36 CST 2018
ot found

第四種,特殊情況,比較一下bash test.sh 2>&1 >test.out 和 bash test.sh >test.out 2>&1 的區別:

root@mengalong:~/opdir/mengalong/t/t# bash test.sh 2>&1 >test.out
test.sh: line 2: t: command not found
root@mengalong:~/opdir/mengalong/t/t# cat test.out
Wed Oct 31 11:12:13 CST 2018

這里只是把 2>&1 放在了 >test.out 前邊,但是結果卻不是像我們想象的那樣,錯誤和正常輸出都進入test.out 文件。這是因為, bash test.sh 2>&1 >test.out 這個命令中, 2>&1 的時候,只是把錯誤輸出重定向到了標準輸出,而此時標準輸出的默認值是屏幕,因此實際等價于標準錯誤輸出被重定向到了屏幕,而非文件。因此重定向需要注意順序。

問題解決

接下來再回過頭來看看,我寫的crontab任務:

01 09 * * * cd /opdir/test/ && ./test.sh &>>test.log

按照上邊的概念分析,這種寫法應該等價于./test.sh >test.log 2>&1 ,腳本執行的輸出和標準錯誤輸出全部重定向到 test.log。但是實際情況卻是test.log文件中并沒有任何內容。

這是因為 crontab 默認使用的shell環境為 /bin/sh, 而/bin/sh 并不支持 &>>test.log 這種重定向方法,因此我們看到的效果是test.log 中沒有內容。

因此解決問題的方法就是將crontab的重定向方法進行修改:

01 09 * * * cd /opdir/test/ && ./test.sh >>test.log 2>&1

啰嗦一句

crontab執行過程中,如果腳本輸出沒有重定向,那么會默認給系統用戶發郵件,郵件內容一般存儲在 /var/mail/$user 中,如果不清理就會打滿服務器根分區,最終導致機器無法登陸。因此推薦的crontab命令寫法如下:

01 09 * * * cd /opdir/test/ && ./test.sh >>test.log 2>&1 </dev/null &

具體后邊增加了 </dev/null & ,這個的含義就不多說了,感興趣的可以自己分析一下

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

標簽:珠海 巴中 張家口 阜陽 湘潭 襄陽 西藏 開封

巨人網絡通訊聲明:本文標題《Linux中crontab輸出重定向不生效問題的解決方法》,本文關鍵詞  Linux,中,crontab,輸出,重定向,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Linux中crontab輸出重定向不生效問題的解決方法》相關的同類信息!
  • 本頁收集關于Linux中crontab輸出重定向不生效問題的解決方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 色护士综合| 妺妺的性放荡日记H| 艳妇臀∴乳欲伦交换H| 精品一区二区三区中文字幕 | 春闺秘史在线阅读| 欧美同志可观看videos| 日本人xxxxxxxx泡妞| 高清三级特黄60分钟在线播放| 成人免费??色情美女视频抹茶| 老司机a湿影院免费| 男人捅女人下边视频| 铁牛tv萌白酱| 两人性潮高免费视频看| 久久97精品国产综合色| 91亚洲国产熟妇无码一区二| 乱h高h禁忌纵欢bl| japan高清日本乱xxxxx| 黄色片子视频| 少妇性猛交ⅩXXX乱大交3男男| 苏晴公交掀裙子从后面进| 三种人不用治幽门杆菌| 在厨房拨开内裤进入毛片| 午夜888888免费视频A片| 乱欲黄蓉| 男人阳茎真实图片| 真实血淋淋处破女| 一女六男NP慎入H| 无碼亂倫凹凸AV视頻| 无人区卡一卡三乱码入口| 小黄网站| 黄色综合网| wwwwxxxx免费| 丰满的上门保洁| 欧美一级黄色影院| 内衣办公室动漫在线h| 天天澡天天狠天干天啪啪按摩性色 | 高中男生洗澡视频露j| 女生逼逼视频| 国产第一页在线播放| 巨胸协议喷奶水WWW动漫下载 | 女明星ai换脸黄网站在线观看|