我在经典Kibana server配置中有一个ELK,查询Elasticsearch个实例。
我使用Kibana控制台对elasticsearch执行复杂的查询。我想使用cURL或任何其他http工具在命令行中使用其中一些查询。
如何将Kibana搜索转换为direct, cURL-like REST call to elasticsearch?
答案 0 :(得分:21)
在可视化底部,您可以单击一个小插入符号以查看有关基础查询的更多详细信息:
然后你可以点击"请求"按钮,以便查看基础查询,您可以复制/粘贴任何适合您的任何内容。
<强>更新强>
然后您可以复制/粘贴来自&#34;请求&#34; textarea并简单地粘贴在这样的卷曲中:
curl -XPOST localhost:9200/your_index/your_type/_search -d '{
"query": {
"filtered": {
"query": {
"query_string": {
"analyze_wildcard": true,
"query": "blablabla AND blablabla"
}
},
"filter": {
"bool": {
"must": [
{
"range": {
"@timestamp": {
"gte": 1439762400000,
"lte": 1439848799999
}
}
}
],
"must_not": []
}
}
}
},
"highlight": {
"pre_tags": [
"@kibana-highlighted-field@"
],
"post_tags": [
"@/kibana-highlighted-field@"
],
"fields": {
"*": {}
}
},
"size": 420,
"sort": {
"@timestamp": "desc"
},
"aggs": {
"2": {
"date_histogram": {
"field": "@timestamp",
"interval": "30m",
"pre_zone": "+02:00",
"pre_zone_adjust_large_interval": true,
"min_doc_count": 0,
"extended_bounds": {
"min": 1439762400000,
"max": 1439848799999
}
}
}
},
"fields": [
"*",
"_source"
],
"script_fields": {},
"fielddata_fields": [
"@timestamp"
]
}'
您可能需要调整一些内容(例如前/后加亮标签等)
答案 1 :(得分:10)
如果您使用Chrome浏览器在线,则可以在开发人员控制台中打开<ul class="columns">
<li class="columns__item">Item 1</li>
<li class="columns__item">Item 2</li>
<li class="columns__item">Item 3</li>
<li class="columns__item">Item 4</li>
<li class="columns__item">Item 5</li>
<li class="columns__item">Item 6</li>
<li class="columns__item">Item 7</li>
<li class="columns__item">Item 8</li>
<li class="columns__item">Item 9</li>
<li class="columns__item">Item 10</li>
<li class="columns__item">Item 11</li>
<li class="columns__item">Item 12</li>
<li class="columns__item">Item 13</li>
<li class="columns__item">Item 14</li>
</ul>
标签的同时,转到Kibana信息中心,打开开发人员控制台并编写查询。当您在Kibana仪表板中搜索查询时,您将看到该请求出现在开发人员控制台中。在那里,您可以“右键单击”并选择Network
,这会将curl命令复制到剪贴板。请注意,您的基本身份验证的凭据也可能会被复制。所以粘贴它时要小心。
答案 2 :(得分:1)
另一种选择是使用ES搜索API query_string
查询使用Lucene查询(Kibana使用相同的语法)查询Elastic Search:
https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-query-string-query.html
从一个文档示例中得出的结果,您将使用以下查询ES:
GET /_search
{
"query": {
"query_string" : {
"default_field" : "content",
"query" : "this AND that OR thus"
}
}
}