我在生产中运行了 ruby on rails 应用程序,这个应用程序有STOCK模型,应该每 1 分钟更新一次。
为了更新这个模型,我创建了简单的 rake 任务db:populate:stocks,它只包含两个操作:
- 截断 STOCK 模型
- 使用从 web 服务获取的最新数据填充 STOCK 模型
这个 rake 任务应该每 1 分钟执行一次,为此我在 gem 时使用。这是我的schedule.rb:
env :PATH, ENV['PATH']
set :job_template, nil
set :output, {:standard => '/home/admin/shared/log/cron.log', :error => '/home/admin/shared/log/cron-error.log'}
job_type :rake, "cd :path && rake :task RAILS_ENV=:environment --trace :output"
every 1.minute do
rake "db:populate:stocks"
end
在生产中,我使用运行 ruby 1.9.2-p180、rails 3.1.0 和 capistrano 的rvm,这里我的 capistrano 任务用于更新 cron 选项卡:
after "deploy:update_code" do
run "cd #{release_path} && whenever --clear-crontab RAILS_ENV=production"
run "cd #{release_path} && whenever --update-crontab RAILS_ENV=production"
end
我的schedule.rb创建 cron 任务,如:
# Begin Whenever generated tasks for: RAILS_ENV=production
PATH=/home/admin/.rvm//gems/ruby-1.9.2-p180@admin/bin:/home/admin/.rvm//gems/ruby-1.9.2-p180@global/bin:/home/admin/.rvm//rubies/ruby-1.9.2-p180/bin:/home/admin/.rvm//bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games
* * * * * cd /home/admin/releases/20120904103658 && RAILS_ENV=production rake db:populate:stocks --trace >> /home/admin/shared/log/cron.log 2>> /home/admin/shared/log/cron-error.log
问题是 cron 任务无法执行 rake 任务,来自cron-error.log:
/home/admin/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems.rb:314:in `bin_path': can't find gem rake ([">= 0"]) with executable rake (Gem::GemNotFoundException)
from /home/admin/.rvm//gems/ruby-1.9.2-p180@admin/bin/rake:19:in `<main>'
我在这里缺少什么,为什么 cron 作业无法加载我的环境?我的schedule.rb有什么问题 吗?