Ansible中的多个json_查询?
我有以下yaml文件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
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将始终返回一个列表,因此如果您只需要一个键的值,则需要将其拉出