gpt4 book ai didi

rubygems - 对资源 `install` 执行操作 'chef_gem[mysql]' 时出错 – 通过 Chef Solo 安装 ruby​​ gem

转载 作者:行者123 更新时间:2023-12-02 08:04:03 26 4
gpt4 key购买 nike

使用 Chef 10.24.0,包含数据库 cookbook 时,

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

mysql gem 安装失败,输出如下:

[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.

为了减少所有可能导致安装失败的变量,我放弃了数据库说明书,并将RubyGem安装限制在mysql::ruby recipe

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

但错误是等效的。

同样适用于最简单的gem_package install:

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

我没有想法,有人可以解释一下吗?

最佳答案

降级到 latest pre-2.0 version (1.8.5) 后使用 RubyGems,一切正常。

此问题很可能是 addressed in RubyGems 2.0.3 .

关于rubygems - 对资源 `install` 执行操作 'chef_gem[mysql]' 时出错 – 通过 Chef Solo 安装 ruby​​ gem,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15328369/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com