Rails 5:Cron作业使用Whenever not running

时间:2017-06-04 06:23:27

标签: ruby-on-rails ruby cron whenever

我正在尝试使用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

1 个答案:

答案 0 :(得分:1)

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

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