首页 > 解决方案 > 如何在多个字段上使用 with_items 从 ansible k8s 模块中检索/解析结果

问题描述

团队,我的任务在 json 输出中运行良好,但我只想查找 pod 名称和命名空间,而不是输出整个 pod json 输出。所以,我正在使用调试来提取 pod 名称,但不确定如何将所有 pod 名称沿边命名空间提取。

任何提示?我无法从这里理解:从 json 输出中提取变量,然后调试并使用 ansible 注册输出

      - name: "Get a list of all pods from any namespace"
        k8s_facts:
          kind: Pod
          namespace: webhook
          kubeconfig: $WORKSPACE
          verify_ssl: no
        register: pod_list
      - debug:
          var: pod_list

      - name: list names and namespaces
        debug:
          msg: "{{ pod_list.resources[0].metadata.name }}"

输出:

TASK [3_validations_on_ssh : list names and namespaces] *******************************************************************************************************************************
ok: [target1] => {
    "msg": "k8s-webhook-auth-xxxx1"
}

查找 pod 的示例输出片段如下:类似地,它会继续查找 pod_lsit 中的其他 pod


TASK [3_validations_on_ssh : debug] *****************************************************
ok: [target1] => {
    "pod_list": {
        "changed": false,
        "failed": false,
        "resources": [
            {
                "apiVersion": "v1",
                "kind": "Pod",
                "metadata": {
                    "creationTimestamp": "2019-10-11T18:44:04Z",
                    "generateName": "k8s-webhook-auth-",
                    "labels": {
                        "app": "k8s-webhook-auth",
                        "controller-revision-hash": "666c6cb69d",
                        "pod-template-generation": "20",
                        "release": "k8s-webhook-auth"
                    },
                    "name": "k8s-webhook-auth-xxxx1",
                    "namespace": "webhook",
                    "ownerReferences": [
                        {
                            "apiVersion": "apps/v1",
                            "blockOwnerDeletion": true,
                            "controller": true,
                            "kind": "DaemonSet",
                            "name": "k8s-webhook-auth",
                            "uid": "1e9-8e9b-ac1f6b4ea082"
                        }
                    ],
                    "resourceVersion": "47592900",
                    "selfLink": "/api/v1/namespaces/webhook/pods/k8s-webhook-auth-5jx6w",
                    "uid": "1e9-8e9b-ac1f6b4ea082"
                },

预期输出:

k8s-webhook-auth-xxxx1 webhook
k8s-webhook-auth-xxxx2 webhook
k8s-webhook-auth-xxxx3 webhook

标签: ansibleansible-2.xansible-facts

解决方案


我认为您需要一个循环来获得您正在寻找的确切输出,但这意味着它不会出现在单个“消息”中,而是每个 pod 中的一条消息,例如:

 - debug:
    msg: "{{ item.metadata.name }} {{ item.metadata.namespace }}"
  loop: "{{ pod_list.resources }}"

另一种选择是使用您需要的数据创建一个新对象。我将在下面给出 2 个示例,但有很多不同的选择。这些示例用于debug显示输出,但您可能希望使用set_fact

 - debug:
    var: pod_list | json_query('resources[].[metadata.name, metadata.namespace]')
 - debug:
    var: pod_list | json_query(query)
  vars:
    query: 'resources[].{name: metadata.name, namespace: metadata.namespace}'

编辑:更多示例

要限制循环中的输出,请查看循环控制文档。下面是一个使用 pod 名称的示例:

- debug:
    msg: "{{ item.metadata.name }} {{ item.metadata.namespace }}"
  loop: "{{ pod_list.resources }}"
  loop_control:
    label: "{{ item.metadata.name }}"

要将输出分配给新变量,请使用set_fact. 请注意,如果与循环结合使用,您的结果将是多个对象的列表。debug这是使用上述任务之一的示例:

- set_fact:
    pods: "{{ pod_list | json_query(query) }}"
  vars:
    query: 'resources[].{name: metadata.name, namespace: metadata.namespace}'

- debug:
    var: pods

推荐阅读