經常有這樣的需求,寫一個python文件,之后把這個python做成定時任務形式,按要求定時crontab執行!
創新互聯公司是一家專注于網站建設、成都網站設計與策劃設計,江城網站建設哪家好?創新互聯公司做網站,專注于網站建設十年,網設計領域的專業建站公司;建站業務涵蓋:江城等地區。江城做網站價格咨詢:18980820575而定時任務經常看到如下格式,譬如我下面這個每三分鐘執行一次,而且把python的輸出信息每次記錄到log日志里面!常用的是
[root@nessus?allpython2019]#?crontab?-e */3?*?*?*?*?/usr/bin/python?/root/allpython2019/1-FtpSwDownloadcfg20191101.py?>>?/root/allpython2019/run.log?2>&1 [root@nessus?allpython2019]#那么這個2>&1 究竟是什么呢?
其實網上很多博文都解釋了,如下:
run.log 2>&1 含義參考https://blog.csdn.net/liupeifeng3514/article/details/79711694
解答:command > a? 2>&1 【command >> a? 2>&1】這條命令,可以理解為執行 command 產生的標準輸入重定向到文件 a 中,標準錯誤也重定向到文件 a 中!(a可以是文件run.log或者/dev/null 空設備文件)【如果不這樣寫 可能只有標準輸出打印到log文件去了? 而stderr并沒有被重定向到log中,stderr被打印到了屏幕上】
下面是我的測試:
(1)測試不加入2>&1 stderr并沒有被重定向到log中,stderr被打印到了屏幕上
(2)測試加入2>&1 stderr也被重定向到log中了
(3)測試常用定時crontab執行時候command > a? 2>&1 和command >> a? 2>&1這2條命令區別,即一個覆蓋!一個是追加!我常用追加!
幾個基本符號及其含義: /dev/null?表示空設備文件; 0?表示stdin標準輸入; 1?表示stdout標準輸出; 2?表示stderr標準錯誤。 例如我寫了下面這個測試程序【這里我們弄了兩條命令,其中t指令并不存在,執行會報錯,會輸出到stderr。date能正常執行,執行會輸出當前時間,會輸出到stdout。】 [root@nessus?allpython2019]#?vim?test.sh #!/bin/sh t date ~ ~ ~ ~ "test.sh"?[新]?3L,?17C?已寫入????????????????????????????????????????????????????????? [root@nessus?allpython2019]#?chmod?+x?test.sh [root@nessus?allpython2019]#?./test.sh?>?res1.log ./test.sh:行2:?t:?未找到命令??????????????#--------可以看到不加入2>&1?stderr并沒有被重定向到log中,stderr被打印到了屏幕上 [root@nessus?allpython2019]#? [root@nessus?allpython2019]#?cat?res1.log? 2019年?11月?01日?星期五?10:01:47?CST [root@nessus?allpython2019]#? [root@nessus?allpython2019]#? [root@nessus?allpython2019]#?./test.sh?>?res2.log?2>&1?#--------可以看到加入2>&1?stderr也被重定向到log中了 [root@nessus?allpython2019]#? [root@nessus?allpython2019]#? [root@nessus?allpython2019]#?cat?res2.log? ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:08?CST [root@nessus?allpython2019]#? [root@nessus?allpython2019]#? [root@nessus?allpython2019]#?./test.sh?>?res2.log?2>&1??#---------------下面演示我們常用的>和>>區別,就是一個覆蓋!一個是追加! [root@nessus?allpython2019]#?cat?res2.log? ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:24?CST [root@nessus?allpython2019]#? [root@nessus?allpython2019]#? [root@nessus?allpython2019]#?./test.sh?>>?res2.log?2>&1 [root@nessus?allpython2019]#?cat?res2.log? ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:24?CST ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:40?CST [root@nessus?allpython2019]#?./test.sh?>>?res2.log?2>&1 [root@nessus?allpython2019]#?cat?res2.log? ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:24?CST ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:40?CST ./test.sh:行2:?t:?未找到命令 2019年?11月?01日?星期五?10:03:44?CST [root@nessus?allpython2019]#? [root@nessus?allpython2019]#? [root@nessus?allpython2019]#另外有需要云服務器可以了解下創新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
本文題目:Linux里的2>&1究竟是什么-創新互聯
轉載來于:http://vcdvsql.cn/article36/jghsg.html
成都網站建設公司_創新互聯,為您提供虛擬主機、電子商務、小程序開發、企業建站、定制開發、App開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯