ElasticSearch Connection Timeout问题的一个神奇的解决方法

栏目: 后端 · 发布时间: 5年前

内容简介:在使用ElasticSearch(版本为6.6.1)处理复杂的搜索时候,我发现会出现timeout的现象。比如说下面的这个,多个通配符查询使用or组合,就出现了timeout的问题。然后我google了一下,google说es默认的timeout是10秒,可以把timeout的时间设置成30,长一点儿。

在使用ElasticSearch(版本为6.6.1)处理复杂的搜索时候,我发现会出现timeout的现象。比如说下面的这个,多个通配符查询使用or组合,就出现了timeout的问题。

query_contains = {
    'query': {
        "bool": {
            "should": [
                {"wildcard": {"name": "*上海*"}},
                {"wildcard": {"scope": "*上海*"}},
                {"wildcard": {"address": "*上海*"}},
            ]
        }
    },
}

ElasticSearch Connection Timeout问题的一个神奇的解决方法

解决方法

然后我google了一下,google说es默认的timeout是10秒,可以把timeout的时间设置成30,长一点儿。

然后我试了一下,确实有点儿效果,报错日志变成了30秒timeout,囧。

ElasticSearch Connection Timeout问题的一个神奇的解决方法

然后我就测了别的查询可以不可以,发现其实是可以的。所以并不是ElasticSearch的不能用了,估计是它反应不过来吧。接下来,我又测了一遍刚刚的复杂查询,发现又可以了,而且响应速度不超过2秒。

所以这个解决方法就是在我们真是搜索前,加一个非常简单的搜索,比如说下面的搜索全部数据,然后再加上我们的复杂查询。

es.search("my_index", doc_type="data", body={'query': {"bool": {"should": []}}})
searched = es.search("cmp_index", doc_type="cmp", body=query_contains, size=10, from_=offset, request_timeout=30)

这个bug就是这么的神奇!


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

中国机器人

中国机器人

[中]王鸿鹏、[中]马娜 / 辽宁人民出版社 / 2017-1-1 / 48.00元

本书对中国机器人领域的发展历史做了引人入胜的介绍,中国机器人成长的过程也是中国经济由弱到强的历程。本书实际是选择了一个独特的视角来解读中国数十年的政治、经济、国家战略问题。中国的未来充满了多重可能性,本书对想了解中国当代与未来发展战略的读者是难得的读本,对智能制造这一当今世界*受关注的高科技领域在战略层面和科技伦理层面进行了深入地剖析和思考,其中提出的诸多前沿性观点是全球都将面对的问题,对中国科学......一起来看看 《中国机器人》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具