当前位置:   article > 正文

解决 Ubuntu 下定时任务不执行问题_no mta installed, discarding output

no mta installed, discarding output

1.创建了一个定时任务

*/1 * * * * /usr/bin/tar -zcPf /data/keymanTech/factorybi-backup/fbi_$(date +%F).tar.gz /data/keymanTech/test

每分钟执行打包压缩文件到指定的目录下,单独执行此命令是可以成功的,但是加入定时任务后就不成功了。

2.查看定时任务日志

Ubuntu 定时任务日志需要手动开启:

  1. root@server01:~# vim /etc/rsyslog.d/50-default.conf
  2. cron.* /var/log/cron.log 把前面的注释去掉,开启 定时任务 日志文件
  3. root@server01:~# service rsyslog restart
  4. # 稍等一会就会出现了
  5. root@server01:~# cat /var/log/cron.log
  6. # 实时查看日志
  7. root@server01:~# tail -f /var/log/cron.log

显示:(CRON) info (No MTA installed, discarding output)

        这个错误原因是cron执行完你的命令后就会给你发一封邮件,但是我邮件都没配置往哪发啊,所以就报错了。难道真的要我把邮箱配置起来嘛,当然不要,目前也不知道怎么配,更不想去配,你执行完就完事了呗,给我发邮件干啥呢。

3.解决办法

我在网上查了许多资料,说是在命令后面把结果重定向到一个自定义创建的文件里面:

  1. */1 * * * * /usr/bin/tar -zcPf /data/keymanTech/factorybi-backup/fbi_$(date +%F).tar.gz /data/keymanTech/test >> /home/log/fbi.log
  2. */1 * * * * /usr/bin/tar -zcPf /data/keymanTech/factorybi-backup/fbi_$(date +%F).tar.gz /data/keymanTech/test >> /dev/null 2>&1 &

但是都不行!!!查看日志依然是 (CRON) info (No MTA installed, discarding output)

我的方法是:

  1. 1.# 创建脚本,把要执行的命令放到脚本里,也要重定向要文件中才可以
  2. root@server01:~# vim cron.sh
  3. /usr/bin/tar -zcPf /data/keymanTech/factorybi-backup/fbi_$(date +"%Y-%m-%d-%H:%M").tar.gz /data/keymanTech/factorybi-backup >> /dev/null 2>&1 &
  4. 2.# 再放到定时任务中
  5. root@server01:~# crontab -e
  6. */1 * * * * /usr/bin/sh /root/cron.sh
  7. 3.# 查看指定目录和日志,执行成功

或者直接在crontab 中:

  1. # 命令行格式
  2. 59 23 * * * /usr/bin/rsync -az --delete root@172.17.23.4::backup /home/busA_mongodb_bak/ --password-file=/etc/rsync.passwd >>/dev/null 2>&1
  3. # 执行脚本格式
  4. 55 23 * * * /fbi/mongodb_bak/mongodb_bak.sh &>/dev/null 2>&1

使用crontab -e修改完以后,并不需要重启服务(sudo service cron restart)

因为定时任务本来就是,一个监听的程序。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/75605?site
推荐阅读
相关标签
  

闽ICP备14008679号