0

我正在尝试使用 Rubber 启动 Amazon EC2 实例。

cap rubber:create_staging

Rubber-ruby.yml 反映正在使用的版本

ruby_build_version: 20141027
ruby_version: 1.9.3-p550

然而,在cap rubber:create_stagingcapistrano 立即中止

LoadError: cannot load such file -- rubber
/Users/you/r/rubbertest/Capfile:14:in `require'

与 capfile 说明

$:.unshift "#{root}/vendor/plugins/rubber/lib/"  # line 13
require 'rubber'                                 # line 14

所以我认为橡胶宝石是必要的。已编辑的 gem 文件(没有 capistrano,该过程早期失败)

gem 'capistrano', '~> 3.1.0'
gem 'capistrano-bundler', '~> 1.1.2'
gem 'capistrano-rails', '~> 1.1.1'
gem 'capistrano-rvm'
gem 'rubber'

这个过程更进一步导致了另一个失败:

NoMethodError: undefined method `instance' for Capistrano::Configuration:Class
/Users/you/.rvm/gems/ruby-1.9.3-p551/gems/rubber-1.15.0/lib/rubber/capistrano.rb:1:in `<top (required)>'
/Users/you/r/rubbertest/Capfile:17:in `require'

capistrano.rb 文件是一个单行

Capistrano::Configuration.instance.load(File.join(File.dirname(__FILE__), 'recipes', 'rubber.rb'))

被capfile调用

Rubber::initialize(root, env)
require 'rubber/capistrano'   # line 17

另一个奇怪的是 Capfile 的最后一条指令调用

Dir['vendor/plugins/*/recipes/*.rb'].each { |plugin| load(plugin) }

并且该目录为空,与说明一致:Rubber can be installed as a ruby​​gem (recommended)

我已经以相同的行为运行了两次。

然而,这些差距(没有提到橡胶宝石,也没有 capistrano,根据 gemmification 偏好调用供应商/插件)告诉我这里缺少一些步骤。这哪里出错了?

4

1 回答 1

0

宝石身份似乎很重要:

#  gem 'rubber'

只会安装版本 1.15.0,通过指定

gem 'rubber', '3.1.0'

然后cap rubber:config运行。create_staging 也将开始运行。
请注意版本是一个问题:最初发布的版本不知何故需要单独的 capistrano 条目并导致后来的失败。版本列表在这里

于 2015-09-17T12:58:47.830 回答