Today I tried to deploy our Ruby on Rails application. Environment: Passenger with Ruby on Rails 1.9.3 (via system-wide-rvm) on FreeBSD. Deployment via a simple capistrano script.
After a successful capistano deploy I get the following error when trying to view it in the browser:
1 2 3 4 5 6 7 8 9 10 | Web application could not be started Could not find rake- 10 . 1 . 0 in any of the sources (Bundler::GemNotFound) /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/spec_set.rb: 92 :in `block in materialize' /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/spec_set.rb: 85 :in `map!' /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/spec_set.rb: 85 :in `materialize' /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/definition.rb: 114 :in `specs' /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/definition.rb: 159 :in `specs_for' /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/definition.rb: 148 :in `requested_specs' /usr/local/rvm/gems/ruby- 1 . 9 . 3 -p392 @generalrails /gems/bundler- 1 . 3 . 5 /lib/bundler/environment.rb: 18 :in `requested_specs' |
When I run rake --version in the selected rvm-environment it just exists.
After searching for while I found the following problem:
Passenger gave the following GEM home:
1 | GEM_HOME = /var/usr/local/www/https_www.webpathy.eu/shared/bundle/ruby/1.9.1 |
When I look in the directory "shared/bundle/ruby" I see everyting is deployed in a directory named: 1.9. The 1.9.1 directory is completely empty!
That's not going to work
WTF!
My quick work-around is the following:
1 | ln -s 1.9 1.9.1 |
Now it's running again...
Does anybody know why bundler first deploys it all in "bundle/ruby/1.9" and passenger tries to grab it from "bundle/ruby/1.9" ?!?!?
I got the same error message and after a lot of digging was able to resolve it by using the rvm/capistrano gem combo as described here:
https://github.com/wayneeseguin/rvm-capistrano
I had used the GEM before but had failed to configure it correctly – after I added the ‘default’ configuration
set :rvm_ruby_string, :local # use the same ruby as used locally for deployment
set :rvm_autolibs_flag, “read-only” # more info: rvm help autolibs
before ‘deploy:setup’, ‘rvm:install_rvm’ # install/update RVM
before ‘deploy:setup’, ‘rvm:install_ruby’ # install Ruby and create gemset, OR:
bundler started installing the gems in the correct shared directory – and my app started without errors.
Thanks for your reply! I will take a look at it. It looks promising :)