Как решить ошибку «Вам нужно добавить gem 'daemons' в ваш Gemfile, если вы хотите использовать его» в производственном режиме? - PullRequest
5 голосов
/ 14 марта 2012

Я пытаюсь правильно использовать Capistrano и RVM для развертывания моего приложения Ruby on Rails 3.2.2 на удаленной машине, на которой работает Ubuntu 10.04 LTS.Именно швы я решил мою предыдущую проблему, связанную с " интеграцией Rvm - Capistrano в Linux Ubuntu ".Однако при развертывании я получаю следующую ошибку, связанную с гемом DelayedJob:

    ...
  * executing "cd /srv/www/<APP_NAME>/releases/20120314135318 && bundle install"
    servers: ["<DOMAIN>"]
    [<DOMAIN>] executing command
    [<DOMAIN>] rvm_path=/usr/local/rvm /usr/local/rvm/bin/rvm-shell 'ruby-1.9.3-p125' -c 'cd /srv/www/<APP_NAME>/releases/20120314135318 && bundle install'     ** [out :: <DOMAIN>] Using rake (0.9.2.2)
 ** [out :: <DOMAIN>] Using builder (3.0.0)
    ...
 ** [out :: <DOMAIN>] Using daemons (1.1.8)
 ** [out :: <DOMAIN>] Using delayed_job (3.0.1)
 ** [out :: <DOMAIN>] Using delayed_job_active_record (0.3.2)
    ...
 ** [out :: <DOMAIN>] Your bundle is complete! It was installed into /srv/www/<APP_NAME>/shared/bundle
    ...
    [<DOMAIN>] executing command
    [<DOMAIN>] rvm_path=/usr/local/rvm /usr/local/rvm/bin/rvm-shell 'ruby-1.9.3-p125' -c 'cd /srv/www/<APP_NAME>/current;  RAILS_ENV=production script/delayed_job stop'
*** [err :: <DOMAIN>] /usr/local/rvm/gems/ruby-1.9.3-p125/gems/delayed_job-3.0.1/lib/delayed/command.rb:4:in `rescue in <top (required)>'
*** [err :: <DOMAIN>] :
*** [err :: <DOMAIN>] You need to add gem 'daemons' to your Gemfile if you wish to use it.
*** [err :: <DOMAIN>] (
*** [err :: <DOMAIN>] RuntimeError
*** [err :: <DOMAIN>] )
*** [err :: <DOMAIN>] from /usr/local/rvm/gems/ruby-1.9.3-p125/gems/delayed_job-3.0.1/lib/delayed/command.rb:1:in `<top (required)>'
*** [err :: <DOMAIN>] from /usr/local/rvm/gems/ruby-1.9.3-p125/gems/activesupport-3.2.2/lib/active_support/dependencies.rb:251:in `require'
*** [err :: <DOMAIN>] from /usr/local/rvm/gems/ruby-1.9.3-p125/gems/activesupport-3.2.2/lib/active_support/dependencies.rb:251:in `block in require'
*** [err :: <DOMAIN>] from /usr/local/rvm/gems/ruby-1.9.3-p125/gems/activesupport-3.2.2/lib/active_support/dependencies.rb:236:in `load_dependency'
*** [err :: <DOMAIN>] from /usr/local/rvm/gems/ruby-1.9.3-p125/gems/activesupport-3.2.2/lib/active_support/dependencies.rb:251:in `require'
*** [err :: <DOMAIN>] from script/delayed_job:4:in `<main>'
    command finished in 7512ms
*** [deploy:update_code] rolling back
    ...

failed: "rvm_path=$HOME/.rvm/ $HOME/.rvm/bin/rvm-shell 'ruby-1.9.3-p125' -c 'cd /srv/www/<APP_NAME>/releases && tar xzf /tmp/20120314140345.tar.gz && rm /tmp/20120314140345.tar.gz'" on <DOMAIN>

Даже если объяснение ошибки: «Вам нужно добавить гем« демоны »в ваш Gemfile, если вы хотите его использовать»,Я уже добавил камень daemons к своему Gemfile (из вышеприведенного вывода вы даже можете заметить, что я "использую демоны (1.1.8)"):

...
gem 'delayed_job'
gem 'delayed_job_active_record'
gem 'daemons'
...

Итак, в чем проблема?Как я могу решить это?


В моем файле deploy.rb у меня есть:

$:.unshift(File.expand_path('./lib', ENV['rvm_path']))
require 'rvm/capistrano'
set :rvm_ruby_string, 'ruby-1.9.3-p125'
set :rvm_type, :user
require 'bundler/capistrano'
...

PS : Вывод окна терминала:

 $ ruby -v
 > ruby 1.9.3p125 (2012-02-16 revision 34643) [i686-linux]
 $ which ruby
 > /usr/local/rvm/rubies/ruby-1.9.3-p125/bin/ruby

1 Ответ

2 голосов
/ 14 марта 2012

Запустить скрипт / delayed_job с пакетом: bundle exec script/delayed_job start

...