linux crontab 定时任务 邮件问题 及其相关的 dead.letter 问题

最近开发项目的时候发现公司服务器用root账号登录的时候 一直会提示有新的信件,一直提示一直提示。

linux crontab 定时任务  邮件问题  及其相关的  dead.letter 问题

联想到另一台服务器上 的dead.letter文件每天都不断的变大  而且在 root家目录里 ,系统硬盘里。过十天半个月就会收到

服务器的磁盘使用率超90%的报警短信, 我突然感觉是时候去除了一下这个问题了。之前就到处搜索dead.letter 问题。但是一直没有

靠谱的跟我这个问题一样的。

行了不废话了 。

linux crontab 定时任务  邮件问题  及其相关的  dead.letter 问题

直入主题,经过不断的搜索。终于在一个外文网站上找到了答案,主要原因我的服务器上有大量的定时任务 crontab ,而crontab中curl命令

执行有输出返回的信息后 ,linux会给对的crontab执行者 返回信息。而这个返回的信息就是通过邮件发给你的,通过邮件你可以查看你的定时任务

执行的情况 。而在这个执行任务的脚本中,有不少的开发小童鞋为了调整输出了不少内容 ,同时这个内容就返回到里你的邮箱里。这个执行一两次没有

什么问题。但是如果他几分钟就执行一次  或者是一分钟执行一次 ,那输出到你邮箱的内容就会很多了 。就像你的邮箱被垃圾流氓骚扰广告邮箱不断的

轰炸一样。

linux crontab 定时任务  邮件问题  及其相关的  dead.letter 问题

而那个 dead.letter  死信也是一样 ,不知道linux对应用户的邮箱没有了 ,被删除掉了。投递信件的时候没有信箱了,这个时候就会生成 dead.letter 。知道这个也就知道如何解决了,

进入 /var/spool/mail/  目录这里是每个用户的信箱  找到缺少的用户  touch 新建一个就可以了 。之后就不会再有死信问题了  。以后再有信件的话就会投入对应的用户文件名中。

说了半天还是没说,怎么去除发送邮件的问题。

还是整理一下英文的那个QA吧,我看明白了  相信你也没问题。



问: 我有一些cron作业在Linux系统上隔夜运行。如果需要查看,这些作业中的每一个都会将信息输出到文本文件中。有些被编写为通过mail命令发送电子邮件。
但是,由于我将这些脚本放在了新系统上并添加到了crontab中,因此我收到了有关运行的每个作业的电子邮件。根目录发送的电子邮件过多。有没有办法停止这种行为?
 
答:  Crond通常在执行cron作业时发送电子邮件。它使用/ etc / crontab中的MAILTO变量来确定谁接收电子邮件,默认情况下该用户是root。有几种方法可以停止此行为。
 
1.将MAILTO变量更改为空白。
 
您可以编辑/ etc / crontab文件,并将MAILTO变量更改为以下内容:
MAILTO=""
 
这将有效地禁用来自cron守护程序的所有电子邮件。然后,您可以在脚本中决定使用mailx命令或您选择的命令发送邮件。
 
这不是我的首选方法,因为当cronjob出现错误时,我希望接收电子邮件。
 
2.将STDOUT和STDERR重定向为null以抑制输出。
 
通过抑制脚本的输出,crond可以发送任何内容。
 
将以下内容添加到crontab条目中,以将所有输出(STDERR和STDOUT)发送到/ dev / null。例如:
>/dev/null 2>&1
 
0 5 * * * /example/script >/dev/null 2>&1
这也有缺点,因为您将抑制所有可能有助于调试脚本问题的错误。
 
3.配置crond将脚本输出发送到系统日志,并禁用发送输出邮件。
 
您可以通过编辑/ etc / sysconfig / crond文件并更改CRONDARGS行来配置crond。添加“ -s”参数会将输出发送到系统日志,添加“ -m off”参数将禁止crond发送作业输出的电子邮件。
 
例如:您将必须重新启动crond服务以读取新的参数:
[root@centos7 ~]# cat /etc/sysconfig/crond
# Settings for the CRON daemon.
# CRONDARGS= :  any extra command-line startup arguments for crond
CRONDARGS=-s -m off
 
 
systemctl restart crond.service
当作业运行时,以上任何一种方法都可以完全抑制来自cron守护程序的电子邮件。这在我看来并不理想,因为如果我的cron作业出现错误,我想得到通知。我更喜欢写我的脚本以不产生任何输出(没有标准输出,但仍然输出错误),或者只将STDOUT重定向到/ dev / null。如果发生错误,这将导致crond仅发送电子邮件。
 
仅仅重定向STDOUT的示例:
0 5 * * * /example/script > /dev/null


这就是我看到的解决方案

改写一下配置就可以了  当然你也可以在每行任务中添加。

看到这个的时候 我也是才明白 fastadmin中推荐的 定时任务的格式 为什么是

* * * * * /usr/bin/php /www/yoursite/public/index.php /addons/crontab/autotask/index > /dev/null  2>&1 &
上一篇:基于PT的ipv6 ripng配置


下一篇:Java的cmd配置(也即Java的JDK配置及相关常用命令)——找不到或无法加载主类 的解决方法