16

我在 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.rbin的输出./log/my_log.log。这种行为是需要的。奇怪的是,我也在本地邮件中收到了输出。我想知道我的脚本的输出是如何被邮件捕获的。由于我将输出重定向到日志文件,我希望我的 cron 作业没有输出,因此当 cron 作业运行时我不会收到任何邮件。任何人都可以阐明邮件如何获得输出./script/my_script.rb吗?

4

3 回答 3

27

您的重定向顺序不正确。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'
于 2013-02-20T15:07:41.427 回答
2

尝试2>&1> ./log/my_log.log.

于 2013-02-20T15:06:35.960 回答
1

这个答案来看,您只需要切换重定向的顺序:

0 5 * * * /bin/bash -l -c 'export RAILS_ENV=my_env; cd /my_folder; ./script/my_script.rb > ./log/my_log.log 2>&1'
于 2013-02-20T15:18:16.323 回答