亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 服務器 > Linux服務器 > 正文

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

2024-09-05 23:05:17
字體:
來源:轉載
供稿:網友

問題

在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.outbash test.sh >test.out 2>&1 //標準輸出和標準錯誤輸出都寫入到test.out并且不會互相覆蓋,等價于 bash test.sh &>test.outbash 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/bashtdateroot@mengalong:~/opdir/mengalong/t/t# bash test.sh >test.outtest.sh: line 2: t: command not foundroot@mengalong:~/opdir/mengalong/t/t# cat test.outWed Oct 31 11:07:24 CST 2018

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

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

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

root@mengalong:~/opdir/mengalong/t/t# bash test.sh >test.out 2>test.outroot@mengalong:~/opdir/mengalong/t/t# cat test.outWed Oct 31 11:10:36 CST 2018ot 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.outtest.sh: line 2: t: command not foundroot@mengalong:~/opdir/mengalong/t/t# cat test.outWed 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 & ,這個的含義就不多說了,感興趣的可以自己分析一下

總結

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


注:相關教程知識閱讀請移步到服務器教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久国产精品三级玉女聊斋| 热re99久久精品国产66热| 中文字幕亚洲欧美一区二区三区| 欧美激情视频在线观看| 国模视频一区二区三区| 狠狠躁夜夜躁人人爽超碰91| 在线播放国产精品| 91tv亚洲精品香蕉国产一区7ujn| 欧美日韩一区二区免费在线观看| 欧美激情第一页xxx| 亚洲国产中文字幕在线观看| 午夜免费久久久久| 91色视频在线导航| 精品成人69xx.xyz| 91午夜在线播放| 亚洲精品v天堂中文字幕| 欧美夫妻性生活视频| 欧美另类交人妖| 97**国产露脸精品国产| 上原亚衣av一区二区三区| 亚洲视频自拍偷拍| 久热精品视频在线观看| 欧美夫妻性视频| 欧美中文字幕精品| 日韩精品福利网站| 国产精品视频一区国模私拍| 国内自拍欧美激情| 日韩中文字幕视频在线观看| 成人欧美一区二区三区在线| 国产精品入口免费视| 日韩电影在线观看免费| 91精品国产成人www| 欧美精品激情blacked18| 亚洲免费视频一区二区| 精品国产一区二区三区久久| 人人澡人人澡人人看欧美| 91久久精品在线| 亚洲国产99精品国自产| 久久久久久中文字幕| 77777亚洲午夜久久多人| 自拍偷拍免费精品| 国产成人一区二区三区电影| 久久久久亚洲精品| 亚洲激情国产精品| 欧美激情乱人伦| 色综合久久88| 奇米4444一区二区三区| 亚洲性夜色噜噜噜7777| 97在线视频免费| 亚洲成人1234| 久久最新资源网| 国产91精品网站| 久久久久久伊人| 久久九九热免费视频| 亚洲精品日韩欧美| 国产成人久久久精品一区| 欧美日韩在线观看视频小说| 久久久久久久久久久免费| 国产欧美日韩综合精品| 亚洲人成电影网| 国产精品久久久久久久美男| 亚洲国产精品成人va在线观看| 亚洲欧美国产制服动漫| 亚洲成成品网站| 夜夜躁日日躁狠狠久久88av| 亚洲成人精品久久久| zzjj国产精品一区二区| 亚洲片国产一区一级在线观看| 欧美做受高潮电影o| 成人免费自拍视频| 亚洲第一精品久久忘忧草社区| 久久久噜噜噜久久中文字免| 亚洲人成网站777色婷婷| 韩日欧美一区二区| 日韩av不卡电影| 在线观看不卡av| 成人免费淫片aa视频免费| 国产一区二区三区直播精品电影| 一区二区三区四区在线观看视频| 国产人妖伪娘一区91| 久久久在线免费观看| 欧美成人黑人xx视频免费观看| 欧美理论在线观看| 欧美大尺度电影在线观看| 中文字幕日韩精品在线| 国内精品久久久久久中文字幕| 亚洲影影院av| 国产美女91呻吟求| 自拍视频国产精品| 成人黄色免费网站在线观看| 日本sm极度另类视频| 中文字幕在线亚洲| 欧美最近摘花xxxx摘花| 亚洲人成77777在线观看网| 色悠久久久久综合先锋影音下载| 亚洲综合中文字幕在线| 欧美另类69精品久久久久9999| 日本一欧美一欧美一亚洲视频| 久久免费视频在线| 国产精品入口免费视频一| 欧美大尺度电影在线观看| 成人免费淫片aa视频免费| 精品国产91乱高清在线观看| 成人激情视频网| 成人97在线观看视频| 国产精品久在线观看| 国产欧美一区二区三区久久人妖| 91精品国产高清久久久久久| 亚洲久久久久久久久久| 国产精品成人免费电影| 国产精品美女999| 久久精品视频中文字幕| 日韩美女写真福利在线观看| 日韩欧美亚洲综合| 91精品国产乱码久久久久久久久| 91av在线影院| 欧美裸体男粗大视频在线观看| 日韩hd视频在线观看| 亚洲乱码一区av黑人高潮| 亚洲色图激情小说| 性欧美暴力猛交69hd| 国内精品久久久久伊人av| 揄拍成人国产精品视频| 欧美国产日产韩国视频| 国产黑人绿帽在线第一区| 欧美高清电影在线看| 欧美日韩成人黄色| 国产精品av在线| 欧洲亚洲免费在线| 欧美乱大交xxxxx| 亚洲图片欧美日产| 国产91精品高潮白浆喷水| 国产精品99久久久久久www| 亚洲高清福利视频| 欧美大成色www永久网站婷| 中文字幕视频在线免费欧美日韩综合在线看| 欧洲永久精品大片ww免费漫画| 亚洲男人的天堂在线| 这里只有精品在线播放| 亚洲欧美激情另类校园| 国产成人在线一区二区| 亚洲激情在线观看| 国产91色在线|| 欧美电影在线观看| 国产精品久久精品| 日韩激情av在线播放| 久久深夜福利免费观看| 久久久国产一区二区| 国产美女精品视频免费观看| 欧美制服第一页| 黑人巨大精品欧美一区免费视频| 中文字幕亚洲欧美日韩2019| 97人人模人人爽人人喊中文字| 欧美激情精品久久久| 美女扒开尿口让男人操亚洲视频网站| 丝袜美腿亚洲一区二区| 欧美性受xxxx白人性爽| 国产精品96久久久久久| 国产在线精品成人一区二区三区| 欧美激情第一页xxx| 日本高清+成人网在线观看| 成人妇女免费播放久久久| 黄色91在线观看| 亚洲电影免费观看高清|