在cron启动定时任务后总是会启动一个[sendmail] 进程的解决方法, 并且每次cron任务之后msmtp.log总是记录一条发送失败的日志

    最近配置服务器上自动编译任务时,每次执行完cron任务之后发现home根目录下的msmtp的log文件有一个发送失败的log,而接收者为执行cron任务的用户名,事实上是因为cron任务有大量输出到标准设备上,从而出发系统的sendmail想把这些输出信息当作邮件发送给用户,而这个用户根本没有邮箱,因而导致msmtp记录了发送失败的log,而这个尝试发送邮件的进程就是[sendmail] <defunct>进程,如果把sendmail指向msmtp的软链接删除掉,这个进程就会变成[cron] <defunct>。

    因此这个问题的解决方法就是把cron任务的输出定向到空设备上: 1>/dev/null 2>&1

 

你可能感兴趣的:(服务器,cron,任务)