1

我正在开发一个节点集群。在myrepo/cookbooks/mycookbook/.kitchen.yml我有

driver:
  name: vagrant

provisioner:
  name: chef_zero
  roles_path: '../../roles'
  environments_path: '../../environments'
  data_bags_path: '../../data_bags'

platforms:
  - name: ubuntu-12.04
    suites:
      - name: node01
        driver:
          vm_hostname: "node01.localhost"
        run_list:
          - role[genericnode]
        provisioner:
            client_rb:
                environment: development

myrepo/cookbooks/mycookbook/recipes/default.rb我有

nodes = []
search(:node, 'role:genericnode').each do |node|
    nodes.push("http://#{node['ipaddress']}:8080")
end

node.default['mysetting'] = nodes.join(',')

但是,在我的开发环境中,搜索返回一个空列表。我是否需要超过上述.kitchen.yml设置才能访问我的网络中具有该角色的节点的 IP 地址genericnode

附加信息:

这是角色:

{
  "name": "genericnode",
  "description": "Generic Node",
  "json_class": "Chef::Role",
  "default_attributes": {

  },
  "override_attributes": {

  },
  "chef_type": "role",
  "run_list": [
    "recipe[apt::default]", "recipe[mycookbook::default]"
  ],
  "env_run_lists": {

  }
}
4

1 回答 1

1

要在 chef_zero 下进行搜索,您需要提供一个节点对象文件夹作为 JSON 来作为被搜索的数据。除非当前节点位于服务器上,否则搜索不会找到当前节点(除非您将其添加到该节点/文件夹中,否则不会找到它。

通常的解决方法是同时使用搜索和检查本地值。

ips = []
search(:node, 'roles:genericnode').each do |n|
    ips << n['ipaddress']
end
if node['roles'].include?'(genericnode')
  ips |= [node['ipaddress']]
end

node.default['mysetting'] = ips.map{|ip| "http://#{ip}:8080"}.join(',')
于 2015-01-05T23:02:03.730 回答