linux crontab 定時任務 郵件問題 及其相關的 dead.letter 問題


最近開發項目的時候發現公司服務器用root賬號登錄的時候 一直會提示有新的信件,一直提示一直提示。

 

聯想到另一台服務器上 的dead.letter文件每天都不斷的變大  而且在 root家目錄里 ,系統硬盤里。過十天半個月就會收到

服務器的磁盤使用率超90%的報警短信, 我突然感覺是時候去除了一下這個問題了。之前就到處搜索dead.letter 問題。但是一直沒有

靠譜的跟我這個問題一樣的。

行了不廢話了 。

 

 

直入主題,經過不斷的搜索。終於在一個外文網站上找到了答案,主要原因我的服務器上有大量的定時任務 crontab ,而crontab中curl命令

執行有輸出返回的信息后 ,linux會給對的crontab執行者 返回信息。而這個返回的信息就是通過郵件發給你的,通過郵件你可以查看你的定時任務

執行的情況 。而在這個執行任務的腳本中,有不少的開發小童鞋為了調整輸出了不少內容 ,同時這個內容就返回到里你的郵箱里。這個執行一兩次沒有

什么問題。但是如果他幾分鍾就執行一次  或者是一分鍾執行一次 ,那輸出到你郵箱的內容就會很多了 。就像你的郵箱被垃圾流氓騷擾廣告郵箱不斷的

轟炸一樣。

 

而那個 dead.letter  死信也是一樣 ,不知道linux對應用戶的郵箱沒有了 ,被刪除掉了。投遞信件的時候沒有信箱了,這個時候就會生成 dead.letter 。知道這個也就知道如何解決了,

進入 /var/spool/mail/  目錄這里是每個用戶的信箱  找到缺少的用戶  touch 新建一個就可以了 。之后就不會再有死信問題了  。以后再有信件的話就會投入對應的用戶文件名中。

 

說了半天還是沒說,怎么去除發送郵件的問題。

還是整理一下英文的那個QA吧,我看明白了  相信你也沒問題。



 

問:  我有一些cron作業在Linux系統上隔夜運行。如果需要查看,這些作業中的每一個都會將信息輸出到文本文件中。有些被編寫為通過mail命令發送電子郵件。
但是,由於我將這些腳本放在了新系統上並添加到了crontab中,因此我收到了有關運行的每個作業的電子郵件。根目錄發送的電子郵件過多。有沒有辦法停止這種行為?
 
答:  Crond通常在執行cron作業時發送電子郵件。它使用/ etc / crontab中的MAILTO變量來確定誰接收電子郵件,默認情況下該用戶是root。有幾種方法可以停止此行為。
 
1.將MAILTO變量更改為空白。
 
您可以編輯/ etc / crontab文件,並將MAILTO變量更改為以下內容:
MAILTO=""
 
這將有效地禁用來自cron守護程序的所有電子郵件。然后,您可以在腳本中決定使用mailx命令或您選擇的命令發送郵件。
 
這不是我的首選方法,因為當cronjob出現錯誤時,我希望接收電子郵件。
 
2.將STDOUT和STDERR重定向為null以抑制輸出。
 
通過抑制腳本的輸出,crond可以發送任何內容。
 
將以下內容添加到crontab條目中,以將所有輸出(STDERR和STDOUT)發送到/ dev / null。例如:
>/dev/null 2>&1
 
0 5 * * * /example/script >/dev/null 2>&1
這也有缺點,因為您將抑制所有可能有助於調試腳本問題的錯誤。
 
3.配置crond將腳本輸出發送到系統日志,並禁用發送輸出郵件。
 
您可以通過編輯/ etc / sysconfig / crond文件並更改CRONDARGS行來配置crond。添加“ -s”參數會將輸出發送到系統日志,添加“ -m off”參數將禁止crond發送作業輸出的電子郵件。
 
例如:您將必須重新啟動crond服務以讀取新的參數:
[root@centos7 ~]# cat /etc/sysconfig/crond
# Settings for the CRON daemon.
# CRONDARGS= :  any extra command-line startup arguments for crond
CRONDARGS=-s -m off
 
 
systemctl restart crond.service
當作業運行時,以上任何一種方法都可以完全抑制來自cron守護程序的電子郵件。這在我看來並不理想,因為如果我的cron作業出現錯誤,我想得到通知。我更喜歡寫我的腳本以不產生任何輸出(沒有標准輸出,但仍然輸出錯誤),或者只將STDOUT重定向到/ dev / null。如果發生錯誤,這將導致crond僅發送電子郵件。
 
僅僅重定向STDOUT的示例:
0 5 * * * /example/script > /dev/null

 



 

 這就是我看到的解決方案

 

 

 改寫一下配置就可以了  當然你也可以在每行任務中添加。

看到這個的時候 我也是才明白 fastadmin中推薦的 定時任務的格式 為什么是 

* * * * * /usr/bin/php /www/yoursite/public/index.php /addons/crontab/autotask/index > /dev/null  2>&1 &

2>&1 的意思就是將標准錯誤重定向到標准輸出。這里標准輸出已經重定向到了 /dev/null。那么標准錯誤也會輸出到/dev/null

可以把/dev/null 可以看作"黑洞". 它等價於一個只寫文件. 所有寫入它的內容都會永遠丟失. 而嘗試從它那兒讀取內容則什么也讀不到.

偶爾也可以把 & 在命令的最后加上,表示讓程序后台執行。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM