crontab執行結果未透過傳送mail通知使用者的方法

佚名發表於2019-09-04

文章主要給大家介紹了關於crontab執行結果未透過傳送mail通知使用者的相關資料,文中透過示例程式碼介紹的非常詳細,對大家學習或者使用linux系統具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

症狀

在某臺 centos7 主機上設定了某個 crontab 任務,但是到時間後執行 mail 後提示 No mail,即cron沒有將任務的執行結果傳送郵件通知到使用者

排查過程

檢查 crontab 日誌

centos的日誌由 systemd 進行管理的,因此可以透過 systemctl 來檢視相關日誌。

journalctl _COMM=crond --since=today

或者用root檢視日誌 /var/log/cron

sudo cat /var/log/cron |grep -v '/usr/local/qcloud/stargate/admin/start.sh'

最終我們在日誌中會看到一行提示 Jun 22 00:50:19 localhost CROND[21181]: (lujun9972) MAIL (mailed 102 bytes of output but got status 0x004b#012)

也就是郵件傳送時失敗了。

檢查 mail 日誌

檢視 /var/log/maillog 日誌會發現日誌中提示 Jun 22 00:50:19 localhost postfix/sendmail[21403]: fatal: parameter inet_interfaces: no local interface found for ::1

也就是說 mail 提示無法為主機上 IPV6 的地址 ::1 發現對應的網路卡

解決方法

註釋掉 /etc/hosts 中 ::1 對應的地址後發現mail的錯誤資訊變成了 postfix/postdrop[5487]: warning: unable to look up public/pickup: No such file or directory

經過搜尋,只需要自己建立缺失檔案再重啟 postfix 服務即可。

sudo mkfifo /var/spool/postfix/public/pickup
sudo chown postfix:postdrop pickup
systemctl restart postfix.service

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,

相關文章