Mcollective Chef 服务代理运行失败



我已经配置了mcollective并安装了以下service代理来start/stop服务

https://github.com/rottenbytes/mcollective/blob/master/plugins/agents/chef-service.rb

但是当我运行它时,它client.build_node失败,我看到错误undefined method reset_defaults_and_overrides for nil:NilClass (NoMethodError)

require 'chef'
require 'chef/client'
require 'chef/run_context'
begin
Chef::Config[:solo] = true
Chef::Config[:log_level] = :debug
Chef::Log.level(:debug)
client = Chef::Client.new
client.run_ohai
client.build_node   <-- its failing here 

如果我尝试在我的外壳上运行,我会得到以下

[root@node1 agent]# ruby /tmp/foo.rb 
/opt/chef/embedded/lib/ruby/gems/1.9.1/gems/chef-11.12.2/lib/chef/policy_builder/expand_node_object.rb:117:in `build_node': undefined method `reset_defaults_and_overrides' for nil:NilClass (NoMethodError)
    from /opt/chef/embedded/lib/ruby/gems/1.9.1/gems/chef-11.12.2/lib/chef/client.rb:259:in `build_node'
    from /tmp/foo.rb:11:in `<main>'

我不是红宝石专家,所以我不知道如何解决它。我只需要知道发生了什么

从外观上看,厨师客户端的内部 API 已经发生了足够的变化,以至于 mcollective 插件将不再工作。尝试旧版本的厨师宝石。

最新更新