重定向cron作业的输出

时间:2013-02-20 15:01:20

标签: bash unix cron crontab

我在crontab中有以下条目:

0 5 * * * /bin/bash -l -c 'export RAILS_ENV=my_env; cd /my_folder; ./script/my_script.rb 2>&1 > ./log/my_log.log'

结果是我在./script/my_script.rb收到./log/my_log.log的输出。这种行为是期望的。奇怪的是,我也在本地邮件中收到输出。我想知道如何通过邮件捕获我的脚本的输出。由于我将输出重定向到日志文件,我希望我的cron作业没有输出,因此当cron作业运行时我不会收到任何邮件。任何人都可以了解邮件如何获得./script/my_script.rb的输出?

3 个答案:

答案 0 :(得分:24)

您的重定向顺序不正确。 Stderr没有被重定向到该文件,而是被发送到stdout。这就是你必须在邮件中收到的内容。

通过将您的cron作业更改为:

来修复重定向
0 5 * * * /bin/bash -l -c
'export RAILS_ENV=my_env;
cd /my_folder;
./script/my_script.rb > ./log/my_log.log 2>&1'

答案 1 :(得分:2)

尝试使用2>&1交换> ./log/my_log.log

答案 2 :(得分:1)

根据this answer判断,您只需要切换重定向的顺序:

0 5 * * * /bin/bash -l -c 'export RAILS_ENV=my_env; cd /my_folder; ./script/my_script.rb > ./log/my_log.log 2>&1'