文章主要給大家介紹了關于crontab執(zhí)行結果未通過發(fā)送mail通知用戶的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用linux系統(tǒng)具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
癥狀
在某臺 centos7 主機上設置了某個 crontab 任務,但是到時間后運行 mail 后提示 No mail,即cron沒有將任務的執(zhí)行結果發(fā)送郵件通知到用戶
排查過程
檢查 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)
也就是郵件發(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)對應的網卡
解決方法
注釋掉 /etc/hosts 中 ::1 對應的地址后發(fā)現(xiàn)mail的錯誤信息變成了 postfix/postdrop[5487]: warning: unable to look up public/pickup: No such file or directory
經過搜索,只需要自己創(chuàng)建缺失文件再重啟 postfix 服務即可。
sudo mkfifo /var/spool/postfix/public/pickup
sudo chown postfix:postdrop pickup
systemctl restart postfix.service
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,
- 利用Bash腳本監(jiān)控Linux服務器的內存使用情況的相關資
- 微軟開始擁抱開源社區(qū) exFAT文件系統(tǒng)向Linux開源
- Linux系統(tǒng)如何安裝配置Sendmail?Linux系統(tǒng)安裝配置Send
- Linux下使用ps命令來查看oracle數(shù)據庫相關進程的操作
- 阿里云服務器宕一次機 要賠償多少錢?
- Windows2000/2003/2008服務器IIS導入服務器證書的方法
- windows服務器配置iis6,iis7.5支持解析.json格式文件
- Win2003服務器防SQL注入的D盾、IIS防火墻的測試情況
- windows服務器下注冊服務的命令小結的相關資料
- 遠程管理Windows服務器上的IIS服務的方法教程