繁体   English   中英

Ansible:根据特定事实计算主机

[英]Ansible: count hosts based on specific fact

我正在使用 Ansible 2.9.13 来管理大约 250 个 ubuntu 客户端。 如果我列出一个客户的所有事实,其中一行是:

"distribution_release": "bionic",

我现在想做的是计算机器的数量,它们是仿生的、焦点的,以及它可能找到的任何其他版本。 所以,像这样:

bionic:  180
focal:   42
precise: 2

这是可能的,如果是,如何?

您可以使用group_by动态创建新的动态组。

---
 - name: Count hosts based on ansible_distribution_release
   hosts: "{{ target|default('all') }}"
   gather_facts: true

   tasks:
    - name: Create dynamic groups
      group_by:
        key: dist_release_{{ ansible_distribution_release }}

 - name: Make the statistics
   hosts: localhost
   gather_facts: false

   tasks:
     - name: Sample output
       debug:
         msg: "Group {{ item }} has {{ groups[item] | length }} hosts."
       when: item.startswith('dist_release_')
       loop: "{{ groups|flatten(levels=1) }}"

第一个 play 基于{{ ansible_distribution_release }}创建动态组,所有组都以前缀dist_

在第二场比赛中,动态组将仅用于创建组和组内主机数量的相当丑陋但有效的统计数据。

如果您愿意,您可以使用 Jinja2 模板创建一个不错的文件输出。

在单个任务中从主机变量创建字典

- hosts: all
  tasks:
    - set_fact:
        distros: "{{ distros|default({})|
                     combine({ item.0: item.1|length }) }}"
      loop: "{{ hostvars|dict2items|
                groupby('value.ansible_distribution_release') }}"
      run_once: true

使用json_query时无需迭代即可创建相同的字典

- hosts: all
  tasks:
    - set_fact:
        distros: "{{ dict(keys|zip(vals)) }}"
      vars:
        dist: "{{ hostvars|dict2items|
                  json_query('[].{distro: value.ansible_distribution_release}')|
                  groupby('distro') }}"
        keys: "{{ dist|map('first')|list }}"
        vals: "{{ dist|map('last')|map('length')|list }}"
      run_once: true

下一个选项是在自定义过滤器的帮助下创建字典

shell> cat filter_plugins/count.py
def count(l):
    d = {}
    for i in set(l):
        d[i] = l.count(i)
    return d

class FilterModule(object):

        def filters(self):
            return {
                'count': count,
                }
- hosts: all
  tasks:
    - set_fact:
        distros: "{{ hostvars|
                     json_query('*.ansible_distribution_release')|
                     count}}"
      run_once: true

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM