重定向cron作业的输出

Mic*_*ick 15 unix bash 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'
Run Code Online (Sandbox Code Playgroud)

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

dog*_*ane 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'
Run Code Online (Sandbox Code Playgroud)

  • 注意,你也可以使用`&>`一次重定向.它适用于zsh和bash. (9认同)
  • 您将stderr重定向到stdout所在的位置(即/ dev/stdout),然后将stdout重定向到您的日志文件.第二次重定向后,Stderr不会更改.它仍然是/ dev/stdout. (2认同)