syslog中的“(CRON)信息(未安装MTA,丢弃输出)”错误,crontab定时任务失效

解决(CRON) info (No MTA installed, discarding output)
问题
使用crontab进行设置定时任务,任务没有执行.
使用命令

tail /var/log/syslog

查看文件,看到cron报错:

(CRON) info (No MTA installed, discarding output)

主要原因
报错的主要原因是没有配置邮件服务器.

导致出错的情况及解决办法
有两种情况会导致这个现象.

(1)命令中含有shell指令
执行命令

crontab -e

查看当前用户的计划任务
当你运行的任务中包含shell命令,就会报错.例如下面的第二个任务:

* * * * * date >log
* * * * * ./temp.sh >`date`.log

可以通过安装邮件服务器解决该问题.
或者是把该shell命令放到一个文件中,执行该文件.然后重定向到null文件.

(2)执行任务过程中会往屏幕输出内容
当你执行的是个脚本文件时,你可以把文件的输出重定向到某个文件中.例如:

* * * * * cd /home/wang && ./temp.sh >temp.log

或者不需要保留执行的输出,则重定向到null中:

* * * * * cd /home/wang && ./temp.sh >/dev/null 2>&1

Linux使用邮件将通知发送给用户。大多数Linux发行版都安装了邮件服务(包括MTA)。Ubuntu没有。
您可以安装邮件服务(例如postfix)来解决此问题。

sudo apt-get install postfix

或者您可以忽略它。我认为cron无法发送消息与CPU峰值无关(这与cron正在运行的基础作业有关)。安装MTA然后阅读消息可能是最安全的(这mutt是一个很好的系统邮件阅读器)。

posted @ 2021-10-11 09:07  flytoyou  阅读(1287)  评论(0编辑  收藏  举报