您好,登錄后才能下訂單哦!
小編給大家分享一下linux中如何實現(xiàn)crontab執(zhí)行結(jié)果未通過發(fā)送mail通知用戶,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
癥狀
在某臺 centos7 主機上設置了某個 crontab 任務,但是到時間后運行 mail 后提示 No mail,即cron沒有將任務的執(zhí)行結(jié)果發(fā)送郵件通知到用戶
排查過程
檢查 crontab 日志
centos的日志由 systemd 進行管理的,因此可以通過 systemctl 來查看相關(guān)日志。
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)
也就是郵件發(fā)送時失敗了。
檢查 mail 日志
查看 /var/log/maillog 日志會發(fā)現(xiàn)日志中提示 Jun 22 00:50:19 localhost postfix/sendmail[21403]: fatal: parameter inet_interfaces: no local interface found for ::1
也就是說 mail 提示無法為主機上 IPV6 的地址 ::1 發(fā)現(xiàn)對應的網(wǎng)卡
解決方法
注釋掉 /etc/hosts 中 ::1 對應的地址后發(fā)現(xiàn)mail的錯誤信息變成了 postfix/postdrop[5487]: warning: unable to look up public/pickup: No such file or directory
經(jīng)過搜索,只需要自己創(chuàng)建缺失文件再重啟 postfix 服務即可。
sudo mkfifo /var/spool/postfix/public/pickup sudo chown postfix:postdrop pickup systemctl restart postfix.service
以上是“l(fā)inux中如何實現(xiàn)crontab執(zhí)行結(jié)果未通過發(fā)送mail通知用戶”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。