我已经设置了 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)
我在这里想念什么?
通常,您会发现这是环境问题。从 cron 运行脚本不会执行该
/etc/profile
脚本。您可以/etc/profile
在脚本的开头获取源代码,或者只设置脚本所需的那些变量(这PATH
是一个很快就会想到的变量)。我建议创建一个小脚本来运行
env
命令并将其通过管道传输到文件中,以便您在从 cron 运行某些东西时可以准确地看到您的环境。应该可以帮助您找到未设置的内容。您尚未将这些作业设置为每分钟、每 5 分钟和每小时运行一次。所有三个都设置为每小时运行一次,在 :01 过去的时间、:05 过去的时间和 :00 过去的时间。相反,您可以尝试类似