文章主要給大家介紹了關(guān)于crontab執(zhí)行結(jié)果未通過(guò)發(fā)送mail通知用戶的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用linux系統(tǒng)具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

癥狀

在某臺(tái) centos7 主機(jī)上設(shè)置了某個(gè) crontab 任務(wù),但是到時(shí)間后運(yùn)行 mail 后提示 No mail,即cron沒(méi)有將任務(wù)的執(zhí)行結(jié)果發(fā)送郵件通知到用戶

排查過(guò)程

檢查 crontab 日志

centos的日志由 systemd 進(jìn)行管理的,因此可以通過(guò) systemctl 來(lái)查看相關(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'

最終我們?cè)谌罩局袝?huì)看到一行提示 Jun 22 00:50:19 localhost CROND[21181]: (lujun9972) MAIL (mailed 102 bytes of output but got status 0x004b#012)

也就是郵件發(fā)送時(shí)失敗了。

檢查 mail 日志

查看 /var/log/maillog 日志會(huì)發(fā)現(xiàn)日志中提示 Jun 22 00:50:19 localhost postfix/sendmail[21403]: fatal: parameter inet_interfaces: no local interface found for ::1

也就是說(shuō) mail 提示無(wú)法為主機(jī)上 IPV6 的地址 ::1 發(fā)現(xiàn)對(duì)應(yīng)的網(wǎng)卡

解決方法

注釋掉 /etc/hosts 中 ::1 對(duì)應(yīng)的地址后發(fā)現(xiàn)mail的錯(cuò)誤信息變成了 postfix/postdrop[5487]: warning: unable to look up public/pickup: No such file or directory

經(jīng)過(guò)搜索,只需要自己創(chuàng)建缺失文件再重啟 postfix 服務(wù)即可。

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

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,