我设置了 3 个 crontab 作业来每分钟、每 5 分钟和每小时定期执行我的简单 ruby 脚本。他们执行,但他们什么也没做。我的机器上只有一个用户 ( root
),并且我已通过执行命令设置了 crontab crontab -e
。crontab -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'