解决 gem whenever 没有定期运行的问题

前一篇博客的标题类似,这两篇内容是一样的,那篇是英文,这篇是中文。

先上结论

短结论:

macOS 开发机跑 spring stop 解决了问题。
Ubuntu 服务器请看文章最后一部分。

长结论:

首先我用 whenever 写好定期任务并且用 whenever -w 写入。
2 分钟后没有看到预期效果。(我定的2分钟一次)

crontab -e 看到命令的确是对的,于是手动把 crontab 里的命令跑了一下,
其中 rails runner 输入之后命令行直接返回了,很奇怪,
于是又尝试了一下 rails console,也是直接返回了,什么效果也没有。
但是 rails s 是能跑起来的。
最后根据这个答案里的 spring stop 解决问题:https://stackoverflow.com/questions/25562083/rails-runner-not-working

whenever 是什么?

https://github.com/javan/whenever/
是个 gem,写定时任务会方便很多。

上面的结论只是为了短,以下多说点情况

今天弄定时任务,需要3小时算一次分。需要每3个小时跑一次定时任务。
于是在 Rails 的 model 里写了 2 个方法一个 cal_score 一个 cal_price

所以 whenever 这边是这样写的:
文件路径 config/schedule.rb

every 2.minute do
  runner "Location.cal_score"
  runner "Location.cal_price"
end

先写 2 分钟测试一下。如果管用了再调整时间就是了。

写完跑了 whenever 看效果。这个命令只是输出转义后的 cronjob 语法,并没有实际修改任何文件,
然后再跑 whenever -w 写入。

按理来说2分钟之后应该生效,因为我在这两个方法的结尾都写了大概10行的代码,给某个 Model 写入新记录,并且有时间的(自带的 created_at 和 updated_at),我就在后台刷新看这个 Model 的记录。

结果没有生效。
我手动看了 crontab -e 里面的命令。rails runner 那个命令我手动跑了不行
rails console 也不行,最后 Stackoverflow 查到 spring stop 解决问题。


上面只解决了 mac 本地机的问题

我弄到 Ubuntu 服务器上结果不行,整整花了一下午才解决。
最后管用的代码:

文件路径 config/schedule.rb

set :path, "/var/www/yuzhu/current"
set :bundle_path, "/usr/local/bin/bundle"
set :rails_path, "/usr/local/bin/rails"
set :output, {:error => "/var/www/random_log/cron_error_log.log", :standard => "/var/www/random_log/cron_log.log"}

job_type :my_rails, 'cd :path && :bundle_path exec :rails_path runner -e production :task :output'

every 3.hours do
  my_rails "Location.cal_score"
  my_rails "Location.cal_price"
end

可以看到定的是 3.hours,你可以先定 1.minute 来测试。测好了再把时间拉长。

感谢阅读