Cron 作业未按预期工作

Cron 作业未按预期工作

我设置了 3 个 crontab 作业来每分钟、每 5 分钟和每小时定期执行我的简单 ruby​​ 脚本。他们执行,但他们什么也没做。我的机器上只有一个用户 ( root),并且我已通过执行命令设置了 crontab crontab -ecrontab -l列出我当前的 crontab 作业:

5 * * * * ruby /root/www/server-monitoring/current/tasks/cpu_check.rb
0 * * * * ruby /root/www/server-monitoring/current/tasks/free_disk_space.rb
1 * * * * ruby /root/www/server-monitoring/current/tasks/free_ram_check.rb

我可以看到它们执行,但不是以正确的时间间隔执行,而且它们不执行任何操作,而如果我手动执行这些 ruby​​ 文件,它们工作得很好。我可以确认 ruby​​ 程序 100% 工作正常,它们通过了测试等。以下是 crontab 日志:

Dec  6 15:45:01 monitoring-jedrzej CRON[28281]: (root) CMD (command -v debian-sa1 > /dev/null && debian-sa1 1 1)
Dec  6 15:55:01 monitoring-jedrzej CRON[28478]: (root) CMD (command -v debian-sa1 > /dev/null && debian-sa1 1 1)
Dec  6 16:00:01 monitoring-jedrzej CRON[28584]: (root) CMD (ruby /root/www/server-monitoring/current/tasks/free_disk_space.rb)
Dec  6 16:01:01 monitoring-jedrzej CRON[28614]: (root) CMD (ruby /root/www/server-monitoring/current/tasks/free_ram_check.rb)
Dec  6 16:05:01 monitoring-jedrzej CRON[28702]: (root) CMD (ruby /root/www/server-monitoring/current/tasks/cpu_check.rb)
Dec  6 16:05:01 monitoring-jedrzej CRON[28703]: (root) CMD (command -v debian-sa1 > /dev/null && debian-sa1 1 1)
Dec  6 16:15:01 monitoring-jedrzej CRON[29214]: (root) CMD (command -v debian-sa1 > /dev/null && debian-sa1 1 1)

我在这里缺少什么?

答案1

一般来说,您会发现这是一个环境问题。从 cron 运行脚本不会执行该/etc/profile脚本。您可以/etc/profile在脚本开始时获取源代码,或者仅设置脚本所需的变量(PATH这是我很快想到的一个变量)。

我建议创建一个运行env命令的小脚本并将其通过管道传输到一个文件,以便您在从 cron 运行某些内容时可以准确地看到您的环境。应该可以帮助您找到需要设置但未设置的内容。

答案2

您尚未将这些作业设置为每分钟、每 5 分钟和每小时运行一次。这三个设置都设置为每小时运行一次,运行时间为整点后 :01、整点后 :05 和整点后:00。相反,你可以尝试类似的东西

* * * * *    echo 'run every minute'
*/5 * * * *  echo 'run every 5 minutes'
0,5,10,15,20,25,30,35,40,45,50,55 * * * *   echo 'alternate every-five-minute'
0 * * * *    echo 'run every hour on the hour'

相关内容