crontab執(zhí)行結(jié)果未通過發(fā)送mail通知用戶的方法
癥狀
在某臺(tái) centos7 主機(jī)上設(shè)置了某個(gè) crontab 任務(wù),但是到時(shí)間后運(yùn)行 mail 后提示 No mail,即cron沒有將任務(wù)的執(zhí)行結(jié)果發(fā)送郵件通知到用戶
排查過程
檢查 crontab 日志
centos的日志由 systemd 進(jìn)行管理的,因此可以通過 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'
最終我們在日志中會(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
也就是說 mail 提示無法為主機(jī)上 IPV6 的地址 ::1 發(fā)現(xiàn)對應(yīng)的網(wǎng)卡
解決方法
注釋掉 /etc/hosts 中 ::1 對應(yīng)的地址后發(fā)現(xiàn)mail的錯(cuò)誤信息變成了 postfix/postdrop[5487]: warning: unable to look up public/pickup: No such file or directory
經(jīng)過搜索,只需要自己創(chuàng)建缺失文件再重啟 postfix 服務(wù)即可。
sudo mkfifo /var/spool/postfix/public/pickup sudo chown postfix:postdrop pickup systemctl restart postfix.service
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。
相關(guān)文章
apache下支持asp.net的實(shí)現(xiàn)方法
讓apache支持asp.net的設(shè)置步驟。2009-12-12
詳解Ubuntu/CentOS下Apache多站點(diǎn)配置
本篇文章主要介紹了Ubuntu/CentOS下Apache多站點(diǎn)配置,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05
Linux如何實(shí)現(xiàn)給/根目錄擴(kuò)容
這篇文章主要介紹了Linux如何實(shí)現(xiàn)給/根目錄擴(kuò)容問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04
Linux如何設(shè)置java.library.path
這篇文章主要介紹了Linux如何設(shè)置java.library.path問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12

