美文网首页
scroll 方式查询es log 示例

scroll 方式查询es log 示例

作者: 慢手暗夜 | 来源:发表于2018-08-27 22:09 被阅读0次

直接上code...

from elasticsearch import Elasticsearch


source_es_ip = "127.0.0.1"
scroll_time = "10m"
scroll_size = 500
es_query_dict = {"query": {"query_string": {
            "query": "tm_timestamp: [2018-08-27T00:00:00 TO 2018-08-28T00:00:00]",
            "default_operator": "AND"}}}

def get_es_logs():
    es_client = Elasticsearch([source_es_ip], port=9200, timeout=300)

    total_docs = 0
    page = es_client.search(scroll=scroll_time,
                            size=scroll_size,
                            body=json.dumps(es_query_dict))
    while True:
        sid = page['_scroll_id']
        details = page["hits"]["hits"]
        doc_count = len(details)
        if len(details) > 0:
            total_docs += doc_count
            # to-do process es logs
        else:
            break
        page = es_client.scroll(scroll_id=sid, scroll=scroll_time)

    print("total docs: " + str(total_docs))

相关文章

网友评论

      本文标题:scroll 方式查询es log 示例

      本文链接:https://www.haomeiwen.com/subject/ryhxwftx.html