日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
Linux中crontab輸出重定向不生效怎么辦-創(chuàng)新互聯(lián)

這篇文章主要介紹Linux中crontab輸出重定向不生效怎么辦,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)專(zhuān)注于市南網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供市南營(yíng)銷(xiāo)型網(wǎng)站建設(shè),市南網(wǎng)站制作、市南網(wǎng)頁(yè)設(shè)計(jì)、市南網(wǎng)站官網(wǎng)定制、小程序定制開(kāi)發(fā)服務(wù),打造市南網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供市南網(wǎng)站排名全網(wǎng)營(yíng)銷(xiāo)落地服務(wù)。

問(wèn)題

在LINUX中,周期執(zhí)行的任務(wù)一般由cron這個(gè)守護(hù)進(jìn)程來(lái)處理[ps -ef|grep cron]。cron讀取一個(gè)或多個(gè)配置文件,這些配置文件中包含了命令行及其調(diào)用時(shí)間。

cron的配置文件稱(chēng)為“crontab”,是“cron table”的簡(jiǎn)寫(xiě)。

近期在crontab中添加了一個(gè)定時(shí)任務(wù),該任務(wù)執(zhí)行之后默認(rèn)會(huì)有正常輸出。為了確保在任務(wù)執(zhí)行過(guò)程中的異常信息也可以捕獲,方便問(wèn)題定位,因此在crontab中我寫(xiě)了這么一條命令:

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

以上命令非常好理解,每天9:01執(zhí)行test.sh 腳本并且將腳本的標(biāo)準(zhǔn)錯(cuò)誤輸出、標(biāo)準(zhǔn)輸出全部重定向到文件 test.log中。最終發(fā)現(xiàn)腳本是正常執(zhí)行了,但是test.log 這個(gè)日志文件中卻沒(méi)有任何內(nèi)容。

為了解決和解釋這個(gè)問(wèn)題,接下來(lái)我們先簡(jiǎn)單介紹下linux系統(tǒng)中重定向的問(wèn)題

概念

Linux系統(tǒng)中:

1: 表示標(biāo)準(zhǔn)輸出(stdout),默認(rèn)輸出到屏幕

2:表示標(biāo)準(zhǔn)錯(cuò)誤輸出(stderr),默認(rèn)輸出到屏幕

在平時(shí)我們經(jīng)常使用如下方法將腳本執(zhí)行結(jié)果重定向:

bash test.sh >test.out //腳本的標(biāo)準(zhǔn)輸出寫(xiě)入到文件test.out ,標(biāo)準(zhǔn)錯(cuò)誤輸出直接打印在屏幕 等價(jià)于:bash test.sh 1>test.out
bash test.sh >test.out 2>&1 //標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯(cuò)誤輸出都寫(xiě)入到test.out并且不會(huì)互相覆蓋,等價(jià)于 bash test.sh &>test.out
bash test.sh >test.out 2>test.out //標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯(cuò)誤輸出都寫(xiě)入到test.out,會(huì)出現(xiàn)互相覆蓋的問(wèn)題,正常情況不推薦這樣使用
bash test.sh &>test.out //等價(jià)于第二種方法

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

第一種:錯(cuò)誤輸出在屏幕,正常輸出在文件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

第二種:錯(cuò)誤輸出和正常輸出均重定向到文件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

第三種:錯(cuò)誤輸出和正常輸出互相覆蓋

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 的區(qū)別:

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 前邊,但是結(jié)果卻不是像我們想象的那樣,錯(cuò)誤和正常輸出都進(jìn)入test.out 文件。這是因?yàn)? bash test.sh 2>&1 >test.out 這個(gè)命令中, 2>&1 的時(shí)候,只是把錯(cuò)誤輸出重定向到了標(biāo)準(zhǔn)輸出,而此時(shí)標(biāo)準(zhǔn)輸出的默認(rèn)值是屏幕,因此實(shí)際等價(jià)于標(biāo)準(zhǔn)錯(cuò)誤輸出被重定向到了屏幕,而非文件。因此重定向需要注意順序。

問(wèn)題解決

接下來(lái)再回過(guò)頭來(lái)看看,我寫(xiě)的crontab任務(wù):

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

按照上邊的概念分析,這種寫(xiě)法應(yīng)該等價(jià)于./test.sh >test.log 2>&1 ,腳本執(zhí)行的輸出和標(biāo)準(zhǔn)錯(cuò)誤輸出全部重定向到 test.log。但是實(shí)際情況卻是test.log文件中并沒(méi)有任何內(nèi)容。

這是因?yàn)?crontab 默認(rèn)使用的shell環(huán)境為 /bin/sh, 而/bin/sh 并不支持 &>>test.log 這種重定向方法,因此我們看到的效果是test.log 中沒(méi)有內(nèi)容。

因此解決問(wèn)題的方法就是將crontab的重定向方法進(jìn)行修改:

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

啰嗦一句

crontab執(zhí)行過(guò)程中,如果腳本輸出沒(méi)有重定向,那么會(huì)默認(rèn)給系統(tǒng)用戶(hù)發(fā)郵件,郵件內(nèi)容一般存儲(chǔ)在 /var/mail/$user 中,如果不清理就會(huì)打滿服務(wù)器根分區(qū),最終導(dǎo)致機(jī)器無(wú)法登陸。因此推薦的crontab命令寫(xiě)法如下:

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

具體后邊增加了

以上是“Linux中crontab輸出重定向不生效怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。


網(wǎng)頁(yè)標(biāo)題:Linux中crontab輸出重定向不生效怎么辦-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)鏈接:http://www.dlmjj.cn/article/dsdchc.html