我正在为golang使用elastic包。我想使用它的BulkProcessor在后台发送大量文档。如wiki所示,我可以创建一个处理器。但我不想每次发送文件时都创建它。我想知道连接中是否存在处理器服务并将数据传递给现有处理器而不是创建新处理器。我怎样才能实现它? 最佳答案 注册批量处理器与发送文件分开。批量处理器的生命周期与您的进程一样长,因此要确保您只创建一次,请在进程启动时创建它。然后在您申请的其他地方,您可以随时发送文件。或者,如果您必须按需进行,您可以使用sync.Once以确保创建只发生一次。
我是elasticsearch的新手,遇到了一些技术难题。目前我有存储在每小时索引中的文档,它们是时间序列数据。我想弄清楚的是如何有效地只提取key字段值,它被定义为"key":{"type":"long"}.我最初尝试了天真的方法,即滚动浏览所有索引并提取字段,但显然这不会很快完成,每个每小时索引都有大约10M文档,滚动3个索引已经花费了很长时间。然后我来到termsaggregations,尝试将key字段作为聚合项:"aggregations":{"test_group":{"terms":{"field":"key","size":100000}}}这给了我更好的性能,但当用户
我必须在我的代码中返回一个elasticsearch查询(Golang使用olivere的elasticv.5库),如果出现特定情况,我希望能够传递一个耗时最短且始终返回null的查询。有没有标准的方法来做到这一点?我尝试使用带有空字符串作为参数的Term查询:elastic.NewTermQuery("","")但这似乎不是一个有效的查询。有什么好的方法吗? 最佳答案 如果“始终返回null”是指不匹配:{"bool":{"must_not":{"match_all":{}}}}我确信match_all的实现非常有效。
尝试在我的树莓派上运行elasticsearch图像时出现错误。它在我的Mac上运行良好,所以它可能是特定于操作系统的。我可以运行其他图像。pi@raspberrypi:~/folder/folder$dockerrunnode:latestpi@raspberrypi:~/folder/folder$dockerrundocker.elastic.co/elasticsearch/elasticsearch:5.6.3standard_init_linux.go:195:execuserprocesscaused"execformaterror"广泛搜索了standard_init_
我有json,我想使用https://godoc.org/gopkg.in/olivere/elastic.v5将其转换为Elasticsearch查询JSON={"query":{"bool":{"filter":[{"exists":{"field":"Videos.en"}}]}}}很简单!到目前为止我所得到的——这显然是行不通的——是:enVidsQuery,err:=elastic.NewBoolQuery().Filter(elastic.Exists("field","Videos.en"))elastic在我的导入中引用了“gopkg.in/olivere/elasti
我有从Elasticsearch返回的数据,使用“github.com/olivere/elastic”。那种工作,当我将它添加到我的结构并将其串起来时,就像这样,data:=Api{Total:myTotal,Data:string(result),}c.JSON(http.StatusOK,totalData)api是这样的结构,typeApistruct{Totalinterface{}Datainterface{}}这将返回数据正常,从1到请求的任意数量的结果。加载到数据接口(interface)的结果如何不转义什么的,例如"Data":"{\"CID\":\"XXXXXXXX
使用olivere/elastic将我的Go(1.10)连接到在Docker容器中运行的Elastic搜索。现在,当数据库有更新时,它将对我的API运行一个触发器,它应该在我的Elastic搜索中搜索该记录,如果没有找到则添加一条新记录,或者如果找到则更新整个记录。现在我有了添加新记录的代码并且可以正常工作,但是我看不到如何更新整个记录,我可以更新该记录的选定元素,但不能更新整个记录。这是我的:testData:=[]byte(`{"data1":"22222","data2":"ddddd"}`)script:=elastic.NewScript("ctx._source=param
我正在使用olivere/elastic在Go中使用elasticsearch。这是我的代码://(1)deletedocument_,err:=e.client.Delete().Index(index).Type("entity").Id(id).Do(e.ctx)iferr!=nil{fmt.Println(err.Error())}//(2)getalldocumentsresult,err:=e.client.Search().Index(index).From(1).Size(100).Do(e.ctx)iferr!=nil{log.Println(err)}fmt.Pri
有谁知道如何解决这个错误?我用Golang向elasticsearch中插入数据,但是好像因为这个错误没有插入数据。{"error":"Content-Typeheader[]isnotsupported","status":406}我已经设置了内容类型。注意我用的是elasticsearch6.4.3request,err:=http.NewRequest("POST",urlSearch,bytes.NewBuffer(query))request.Close=truerequest.Header.Set("Content-Type","application/json")最后但同
我在尝试使用elastigo将数据插入elasticsearch时收到此错误。错误是{"error":"Content-Typeheader[]isnotsupported","status":406}有谁知道如何将内容类型header设置为elastigo?我认为Elastigo不适用于elasticsearch6.4.3,我是否应该更改为olivere包来向elasticsearch发出请求? 最佳答案 shouldIchangetooliverepackagetomakerequeststoelasticsearch?是的