背景: 我看过 这个问题这个 - 可悲的是,没有结果。

错误消息(乘客): 您已经激活了机架 1.1.0,但您的 Gemfile 需要机架 1.2.1。考虑使用捆绑执行。

我的宝石文件:

source 'http://rubygems.org'

gem 'rails', '3.0.0.rc'
gem 'nifty-generators' 
gem 'nokogiri'
group :after_initialize do
    gem 'feedzirra'
end

我的 Gemfile.lock 有这一行:

rack (1.2.1)

我的environment.rb 顶部有这一行:

ENV['GEM_PATH'] = File.expand_path('~/.gems') + ':/usr/lib/ruby/gems/1.8'

我的 boot.rb 顶部有这一行:

Gem.clear_paths

我在本地正确安装了rack(1.2.1) - 我的应用程序在本地主机上运行良好,并且版本1.2.1显示在终端中的“gem列表”之后。

在将我的应用程序推送到生产服务器之前,我已将我的 gems 打包为“捆绑包”。

在部署之前,我已运行以下命令(在我的生产服务器上,从应用程序的根目录):

bundle install --path vendor/bundle --local

执行上面的安装命令后,“捆绑检查”将返回以下内容:

The Gemfile's dependencies are satisfied

这是乘客提供的回溯(以及上面提到的错误消息):

0   /home/user/.gems/gems/bundler-1.0.0/lib/bundler/runtime.rb      27      in `setup'
1   /home/user/.gems/gems/bundler-1.0.0/lib/bundler/spec_set.rb     12  in `each'
2   /home/user/.gems/gems/bundler-1.0.0/lib/bundler/spec_set.rb     12  in `each'
3   /home/user/.gems/gems/bundler-1.0.0/lib/bundler/runtime.rb  17  in `setup'
4   /home/user/.gems/gems/bundler-1.0.0/lib/bundler.rb  100     in `setup'
5   /home/user/gseeds.mywebsite.com/releases/20100927012812/config/boot.rb  9   
6   /usr/lib/ruby/1.8/rubygems/custom_require.rb    31  in `gem_original_require'
7   /usr/lib/ruby/1.8/rubygems/custom_require.rb    31  in `require'
8   /home/user/gseeds.mywebsite.com/releases/20100927012812/config/application.rb   1   
9   /usr/lib/ruby/1.8/rubygems/custom_require.rb    31  in `gem_original_require'
10  /usr/lib/ruby/1.8/rubygems/custom_require.rb    31  in `require'
11  /home/user/gseeds.mywebsite.com/releases/20100927012812/config/environment.rb   7   
12  /usr/lib/ruby/1.8/rubygems/custom_require.rb    31  in `gem_original_require'
13  /usr/lib/ruby/1.8/rubygems/custom_require.rb    31  in `require'
14  config.ru   3   
15  /usr/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/builder.rb  46  in `instance_eval'
16  /usr/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/builder.rb  46  in `initialize'
17  config.ru   1   in `new'
18  config.ru   1 

我想知道是否有人想出了解决方案?

应该注意的是,示例 Rails 应用程序(即运行 Rails new appName 并将其直接 ftp 到 DreamHost 上的生产服务器)将运行良好。这让我感到不安,因为我想象我的真实应用程序和示例应用程序都具有机架(1.2.1)依赖项;这对我来说意味着,为了绕过 DreamHost 服务器 gem,我在某种程度上搞乱了真实应用程序中的rack 实现。

我的示例 Rails 应用程序在 DreamHost 上的单独子域上运行,而我尝试部署的两个实际应用程序的子域均出现此错误。

另外,在采用供应商/缓存方法之前,我最初尝试在 DreamHost 用户目录中本地安装 gem。也许这并不影响什么..

感谢您经历这个混乱/冗长的问题

有帮助吗?

解决方案

向 Dreamhost 投诉并告诉他们升级 Phusion Passenger。此问题现已在 Phusion Passenger 的多个版本中得到修复。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top