3

Chef 10.24.0 を使用して、クックブックを含めるdatabase

include_recipe "mysql::server"
include_recipe "database::mysql"

gemのmysqlインストールに失敗し、次の出力が表示されます。

[2013-03-10T19:54:29+00:00] INFO: Processing chef_gem[mysql] action install (mysql::ruby line 36)

================================================================================
Error executing action `install` on resource 'chef_gem[mysql]'
================================================================================

NoMethodError
-------------
undefined method `last' for #<Gem::AvailableSet:0x00000002b25be0>

Cookbook Trace:
---------------
/tmp/vagrant-chef-1/chef-solo-1/cookbooks/mysql/recipes/ruby.rb:36:in `from_file'
/tmp/vagrant-chef-1/chef-solo-1/cookbooks/database/recipes/mysql.rb:20:in `from_file'
/tmp/vagrant-chef-1/chef-solo-1/cookbooks/scafandru/recipes/database.rb:11:in `from_file'

Resource Declaration:
---------------------
# In /tmp/vagrant-chef-1/chef-solo-1/cookbooks/mysql/recipes/ruby.rb

 36: chef_gem "mysql"

Compiled Resource:
------------------
# Declared in /tmp/vagrant-chef-1/chef-solo-1/cookbooks/mysql/recipes/ruby.rb:36:in `from_file'

chef_gem("mysql") do
  provider Chef::Provider::Package::Rubygems
  action :install
  retries 0
  retry_delay 2
  package_name "mysql"
  cookbook_name :mysql
  recipe_name "ruby"
end


================================================================================
Recipe Compile Error in /tmp/vagrant-chef-1/chef-solo-1/cookbooks/scafandru/recipes/database.rb
================================================================================

NoMethodError
-------------
chef_gem[mysql] (mysql::ruby line 36) had an error: NoMethodError: undefined method `last' for #<Gem::AvailableSet:0x00000002b25be0>

Cookbook Trace:
---------------
  /tmp/vagrant-chef-1/chef-solo-1/cookbooks/mysql/recipes/ruby.rb:36:in `from_file'
  /tmp/vagrant-chef-1/chef-solo-1/cookbooks/database/recipes/mysql.rb:20:in `from_file'
  /tmp/vagrant-chef-1/chef-solo-1/cookbooks/scafandru/recipes/database.rb:11:in `from_file'

Relevant File Content:
----------------------
/tmp/vagrant-chef-1/chef-solo-1/cookbooks/mysql/recipes/ruby.rb:

 29:  include_recipe "build-essential"
 30:  include_recipe "mysql::client"
 31:  
 32:  node['mysql']['client']['packages'].each do |mysql_pack|
 33:    resources("package[#{mysql_pack}]").run_action(:install)
 34:  end
 35:  
 36>> chef_gem "mysql"
 37:  

[2013-03-10T19:54:31+00:00] ERROR: Running exception handlers
[2013-03-10T19:54:31+00:00] ERROR: Exception handlers complete
[2013-03-10T19:54:31+00:00] FATAL: Stacktrace dumped to /tmp/vagrant-chef-1/chef-stacktrace.out
[2013-03-10T19:54:31+00:00] FATAL: NoMethodError: chef_gem[mysql] (mysql::ruby line 36) had an error: NoMethodError: undefined method `last' for #<Gem::AvailableSet:0x00000002b25be0>
Chef never successfully completed! Any errors should be visible in the
output above. Please fix your recipes so that they properly complete.

インストールが失敗する可能性のあるすべての変数を削減しようとして、クックブックを破棄し、レシピdatabaseで RubyGem のインストールに制限しましたmysql::ruby

include_recipe "mysql::server"
include_recipe "mysql::ruby"

しかし、エラーは同等でした。

gem_package 最も単純なインストールにも同じことが当てはまります:

gem_package 'mysql' do
  options "--no-ri --no-rdoc"
end

私はアイデアがありません。誰かがこれに光を当てることができますか?

4

1 に答える 1

3

RubyGemsの 2.0 より前の最新バージョン (1.8.5)にダウングレードすると、すべて正常に動作します。

この問題は、RubyGems 2.0.3 で対処される可能性が高いです。

于 2013-03-10T23:31:45.090 に答える