Rails 5:使用 Whenever not 运行 的 Cron 作业

Rails 5: Cron jobs using Whenever not running

我正在尝试使用 Whenever gem 每小时完成一项任务 运行。

#check_price.rake
namespace :check_price do
  desc "TODO"
  task check_now: :environment do
    price_sync = PriceSyncLibrary.new
    Product.all.each do |product|
      product.price.push(price_sync.get_price_from_link(product.flipkart_link))
      product.time.push(Time.now)
      product.save!
    end
  end  
end

这是我的 schedule.rb 文件

every 1.minute do
  rake "check_price:check_now", environment: 'development' 
end

当我运行

rake check_price:check_now

在终端中,我得到了我想要的结果,但是同一个 rake 任务并不是 运行 每一分钟都在 schedule.rb 文件中指定的。我错过了什么吗?

当我运行

crontab -l

在控制台中,我得到了这个结果。

# Begin Whenever generated tasks for: /home/raghav/workspace/apps/Shotgun/config/schedule.rb
* * * * * /bin/bash -l -c 'cd /home/raghav/workspace/apps/Shotgun && RAILS_ENV=production bundle exec rake check_price:check_now --silent'

# End Whenever generated tasks for: /home/raghav/workspace/apps/Shotgun/config/schedule.rb

# Begin Whenever generated tasks for: Shotgun
* * * * * /bin/bash -l -c 'cd /home/raghav/workspace/apps/Shotgun && RAILS_ENV=production bundle exec rake check_price:check_now --silent'

# End Whenever generated tasks for: Shotgun

在您的 schedule.rb 文件中,您的环境设置为开发环境,在 crontab -l 命令的响应中,环境设置为生产环境, 你可以这样设置环境,

set :environment, "development"
set :output, {:error => "log/cron_error_log.log", :standard => "log/cron_log.log"}

every 1.minute do
  rake "check_price:check_now"
end