Ansible中的多个json_查询?

Ansible中的多个json_查询?,ansible,json-query,Ansible,Json Query,我有以下yaml文件 resources: - apiVersion: v1 kind: Deployment metadata: labels: app: test name: test-cluster-operator namespace: destiny001 spec: selector: matchLabels: name: test-cluster-oper

我有以下yaml文件

resources:
  - apiVersion: v1
    kind: Deployment
    metadata:
      labels:
        app: test
      name: test-cluster-operator
      namespace: destiny001
    spec:
      selector:
        matchLabels:
          name: test-cluster-operator
          test.io/kind: cluster-operator
      strategy:
        type: Recreate
      template:
        metadata:
          labels:
            name: test-cluster-operator
            test.io/kind: cluster-operator
        spec:
          containers:
          - args:
            - /path/test/bin/cluster_operator_run.sh
            env:
            - name: MY_NAMESPACE
              valueFrom:
                fieldRef:
                  apiVersion: v1
                  fieldPath: metadata.namespace
            imagePullPolicy: IfNotPresent
            livenessProbe:
              failureThreshold: 3
              httpGet:
                path: /healthy
                port: 8080
                scheme: HTTP
              initialDelaySeconds: 10
              periodSeconds: 30
              successThreshold: 1
              timeoutSeconds: 1
            name: test-cluster-operator
            readinessProbe:
              failureThreshold: 3
              httpGet:
                path: /ready
                port: 8080
                scheme: HTTP
              initialDelaySeconds: 10
              periodSeconds: 30
              successThreshold: 1
              timeoutSeconds: 1
            resources:
              limits:
                cpu: '1'
                memory: 256Mi
              requests:
                cpu: 200m
                memory: 256Mi
            terminationMessagePath: /dev/termination-log
            terminationMessagePolicy: File
            volumeMounts:
            - mountPath: /var/data
              name: data-cluster-operator
          dnsPolicy: ClusterFirst
          restartPolicy: Always
          schedulerName: default-scheduler
          securityContext: {}
          serviceAccount: test-cluster-operator
          serviceAccountName: test-cluster-operator
          terminationGracePeriodSeconds: 30
          volumes:
          - name: data-cluster-operator
            persistentVolumeClaim:
              claimName: data-cluster-operator
我正在尝试获取名为MY_NAMESPACE的env变量的值。 这就是我在Ansible中试图到达环境树路径的地方

- name: "set test fact"
  set_fact:
    myresult: "{{ yaml_file_variable | json_query(\"resources[?metadata.name=='test-cluster-operator'].spec.template.spec\") | json_query(\"containers[?name=='test-cluster-operator'].env\") }}"

- name: "debug"
  debug:
    msg: "{{ myresult }}"
这将生成一个空列表,但是第一个json_查询运行良好

在这种情况下,如何正确使用json_查询? 我可以通过一个json_查询来实现这一点吗

编辑: 我似乎更接近于一个解决方案,但结果是一个列表而不是字符串,我觉得这很烦人

- name: "set test fact"
  set_fact:
    myresult: "{{ yaml_file_variable | json_query(\"resources[?metadata.name=='test-cluster-operator'].spec.template.spec\") | json_query(\"[].containers[?name=='test-cluster-operator']\") | json_query(\"[].env[?name=='MY_NAMESPACE'].name\") }}"
这将打印--我的\u名称空间,而不仅仅是我的\u名称空间

每次json_查询之后,我都必须使用第一个过滤器吗?我确信只有一个containers元素。我不明白为什么json_查询返回一个列表

这终于起作用了,但不知道这是否是正确的方法

- name: "set test fact"
  set_fact:
    myresult: "{{ yaml_file_variable | json_query(\"resources[?metadata.name=='test-cluster-operator'].spec.template.spec\") | first | json_query(\"containers[?name=='test-cluster-operator']\") | first | json_query(\"env[?name=='MY_NAMESPACE'].valueFrom \") | first }}"

json_查询使用jmespath,jmespath总是返回一个列表。这就是为什么您的第一个示例不起作用。第一个查询返回一个列表,但第二个查询试图查询一个键。您已在第二节中用[]更正了此问题

您还缺少jmespath管道表达式:|正如您所期望的那样使用它-第一个查询的结果可以通过管道传输到新的查询中。请注意,这与使用相同字符的ansible筛选器不同

此查询:

resources[?metadata.name=='test-cluster-operator'].spec.template.spec | [].containers[?name=='test-cluster-operator'][].env[].valueFrom
应为您提供以下输出:

[
  {
    "fieldRef": {
      "apiVersion": "v1",
      "fieldPath": "metadata.namespace"
    }
  }
]
您的任务应该如下所示:

- name: "set test fact"
  set_fact:
    myresult: "{{ yaml_file_variable | json_query(\"resources[?metadata.name=='test-cluster-operator'].spec.template.spec | [].containers[?name=='test-cluster-operator'][].env[].valueFrom\") | first }}"
要回答您的另一个问题,是的,您将需要使用第一个过滤器。如前所述,jmespath将始终返回一个列表,因此如果您只需要一个键的值,则需要将其拉出