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