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