我在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'
这样做的结果是我在./log/my_log.log
接收到./script/my_script.rb
的输出。 这种行为是需要的。 奇怪的是,我也收到我的本地邮件的输出。 我想知道如何通过邮件捕获我的脚本的输出。 由于我将输出redirect到一个日志文件,所以我期望我的cron作业没有输出,因此在cron作业运行时我不会收到邮件。 任何人都可以阐明如何邮件能够得到./script/my_script.rb
的输出?
您的重定向顺序不正确。 Stderr没有被重定向到文件,而是被发送到标准输出。 这就是你必须收到你的邮件。
通过更改您的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'
尝试使用> ./log/my_log.log
交换2>&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'