我在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
的输出?
答案 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'