2011-08-21 60 views
1

在EY AppCloud中,即使在开发环境中运行,它们也会运行bundler - 无需开发和测试。我的Gemfile包含此在文本,开发环境中使用ruby-debug19在AppCloud上部署错误

group :test, :development do 
    gem 'ruby-debug19', :require => 'ruby-debug' 
end 

,当我部署我得到这个错误:

Successfully installed engineyard-serverside-1.4.2 
1 gem installed 
~> Deploying revision a01f92c migrating to new FactoryGirl 
~> Pushing code to all servers 
~> Starting full deploy 
~> Copying to /data/eg/releases/20110821184344 
~> Ensuring proper ownership 
~> Gemfile detected, bundling gems 
~> Symlinking configs 
ln: creating symbolic link `/data/eg/releases/20110821184344/config/database.yml': File exists 
~> Migrating: cd /data/eg/releases/20110821184344 && PATH=/data/eg/releases/20110821184344/ey_bundler_binstubs:$PATH RAILS_ENV=development RACK_ENV=development MERB_ENV=development rake db:migrate --trace 
rake aborted! 
no such file to load -- ruby-debug 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler/runtime.rb:68:in `require' 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler/runtime.rb:68:in `block (2 levels) in require' 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler/runtime.rb:66:in `each' 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler/runtime.rb:66:in `block in require' 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler/runtime.rb:55:in `each' 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler/runtime.rb:55:in `require' 
/usr/lib/ruby/gems/1.9.1/gems/bundler-1.0.15/lib/bundler.rb:120:in `require' 
/data/eg/releases/20110821184344/config/application.rb:7:in `<top (required)>' 
/data/eg/releases/20110821184344/Rakefile:5:in `require' 
/data/eg/releases/20110821184344/Rakefile:5:in `<top (required)>' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/rake_module.rb:25:in `load' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/rake_module.rb:25:in `load_rakefile' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:495:in `raw_load_rakefile' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:78:in `block in load_rakefile' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:129:in `standard_exception_handling' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:77:in `load_rakefile' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:61:in `block in run' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:129:in `standard_exception_handling' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/application.rb:59:in `run' 
/data/eg/shared/bundled_gems/ruby/1.9.1/gems/rake-0.9.2/bin/rake:32:in `<top (required)>' 
/data/eg/releases/20110821184344/ey_bundler_binstubs/rake:16:in `load' 
/data/eg/releases/20110821184344/ey_bundler_binstubs/rake:16:in `<main>' 
~> [Attention] Maintenance page still up, consider the following before removing: 
* any deploy hooks ran, be careful if they were destructive 
* any migrations ran, be careful if they were destructive 
* your old code is still symlinked as current 
Failed deployment recorded in AppCloud 
Deploy failed 

如果我注释掉宝石“红宝石debug19”线的Gemfile它的工作原理。但是,正如前面提到的那样,AppCloud忽略了测试和开发环境。它在两种情况下在本地都有效。任何人都可以想到什么可能会导致这种情况?

回答

3

我相信这是因为config/application.rb调用Bundler.require与几个组名称,其中之一是Rails.env。您在命令行上的RAILS_ENVdevelopment,这意味着Bundler.require正试图加载development组并需要其中的东西,其中包括ruby-debug。由于该软件包已安装development组,因此它会中断。

可能是最好的运行你的应用程序时本地,要么stagingproduction对AppCloud您的应用程序使用developmentRAILS_ENV

+0

为什么安永会这么做呢?看起来在任何情况下,你只在开发组中放入某些东西,应用程序将无法启动(在EY上的开发模式下)b/c时,它不会安装application.rb然后尝试要求的那些gem。另外,在运行“捆绑安装 - 无需开发测试”之后,我无法在本地重现这一点。这似乎很奇怪。谢谢! – 99miles

+0

为什么安永会做什么?我可以在本地复制它:https://gist.github.com/1162178。当':require =>'ruby-debug19'出现时,它似乎只会中断。这可能是捆绑商的一个错误。 – dpiddy

相关问题