我正在尝试构造curl API查询以从Prometheus获取Json数据。在Prometheus UI查询中的工作方式如下:
max_over_time(container_memory_usage_bytes{image!="",pod_name=~"somepod-.*"}[7d])
所以我正在尝试:
curl 'http://127.0.0.1:20001/api/v1/query?query=max_over_time(container_memory_usage_bytes{(pod_name="somepod-.*")})[1d]' | jq
但是根据括号的不同,它总是抱怨诸如预期或意外字符之类的东西。
答案 0 :(得分:1)
您要
curl -g 'http://127.0.0.1:20001/api/v1/query?query=max_over_time(container_memory_usage_bytes{pod_name=~"somepod-.*"}[1d])' | jq
这将禁用curl的globbing,这会妨碍到这里。
答案 1 :(得分:0)
我在下面使用此查询从prometheus中获得一个相当复杂的查询,并使用jq提取有趣的信息,然后将其格式化为csv
curl -fs --data-urlencode 'query=sort_desc( sum(container_memory_working_set_bytes) by (container_name, namespace) /sum(label_join(kube_pod_container_resource_requests_memory_bytes, "container_name", "", "container")) by (container_name, namespace) > 1)' https://prometheus/api/v1/query | jq -r '.data.result[] | [.metric.container_name, .metric.namespace, .value[1] ] | @csv'
您可以在https://learndevops.substack.com/p/hitting-prometheus-api-with-curl
查看更多信息