草庐IT

elasticsearch-rest-high-level-cli

全部标签

elasticsearch - 如何检查 ElasticSearch BulkProcessor 服务是否存在

我正在为golang使用elastic包。我想使用它的BulkProcessor在后台发送大量文档。如wiki所示,我可以创建一个处理器。但我不想每次发送文件时都创建它。我想知道连接中是否存在处理器服务并将数据传递给现有处理器而不是创建新处理器。我怎样才能实现它? 最佳答案 注册批量处理器与发送文件分开。批量处理器的生命周期与您的进程一样长,因此要确保您只创建一次,请在进程启动时创建它。然后在您申请的其他地方,您可以随时发送文件。或者,如果您必须按需进行,您可以使用sync.Once以确保创建只发生一次。

rest - Golang 服务响应文件

如何在Go中更有效地从服务返回文件?例如,我收到这样一个文件这是我用来从服务接收文件的示例:func(b*BenefitListHandler)UploadAppend(whttp.ResponseWriter,r*http.Request){r.ParseMultipartForm(32在那之后,我很困惑如何从该请求发送另一个文件,如二进制文件,以减少时间和消耗。 最佳答案 查看有关问题的信息后,我得到了解决方案为了指定浏览器是一个文件,我将该header放入响应中:w.Header().Set("Content-Disposit

rest - 为什么 Go 包显示为未定义?

我无法理解以下代码的问题所在。VisualStudioCode编译器给我如下错误,因为包“util”未定义。'Error'message:'undefined:util.GetPortAndURL我将以下内容放在我的util.go文件的顶部packageutil我还在我的handlers.go文件中导入了包myproj/util,这是在其init方法中调用以下代码的文件。file,err:=ioutil.ReadFile("./creds.json")iferr!=nil{fmt.Printf("Fileerror:%v\n",err)//useabettererrorpatternh

elasticsearch - 如何有效地只获取文档的一个字段进行 Elasticsearch

我是elasticsearch的新手,遇到了一些技术难题。目前我有存储在每小时索引中的文档,它们是时间序列数据。我想弄清楚的是如何有效地只提取key字段值,它被定义为"key":{"type":"long"}.我最初尝试了天真的方法,即滚动浏览所有索引并提取字段,但显然这不会很快完成,每个每小时索引都有大约10M文档,滚动3个索引已经花费了很长时间。然后我来到termsaggregations,尝试将key字段作为聚合项:"aggregations":{"test_group":{"terms":{"field":"key","size":100000}}}这给了我更好的性能,但当用户

elasticsearch - 有没有办法通过 Elasticsearch 查询故意返回空值?

我必须在我的代码中返回一个elasticsearch查询(Golang使用olivere的elasticv.5库),如果出现特定情况,我希望能够传递一个耗时最短且始终返回null的查询。有没有标准的方法来做到这一点?我尝试使用带有空字符串作为参数的Term查询:elastic.NewTermQuery("","")但这似乎不是一个有效的查询。有什么好的方法吗? 最佳答案 如果“始终返回null”是指不匹配:{"bool":{"must_not":{"match_all":{}}}}我确信match_all的实现非常有效。

docker - 无法在 Raspberry Pi 上运行 elasticsearch 镜像

尝试在我的树莓派上运行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_

elasticsearch - 将 Elasticsearch DSL 翻译成 gopkg.in/olivere/elastic.v5

我有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

rest - 从客户端向服务器发送数据 - REST webservice

我正在使用RESTfulWeb服务开发客户端-服务器应用程序。我想在客户端请求用户输入并将其发送到服务器并在我的程序的其余部分使用该名称,但我无法将该名称正确发送到服务器。下面是我的程序的一部分:客户:funcmain(){//gettinginputfmt.Println("Pleaseenteryourname:")reader:=bufio.NewReader(os.Stdin)myName,_:=reader.ReadString('\n')client:=&http.Client{CheckRedirect:nil,}reply,err:=http.NewRequest("G

mongodb - REST API + MongoDb ISODate

我的GoLang结构:typemyPojostruct{IDbson.ObjectId`json:"id"bson:"_id,omitempty"`Starttime.Time`json:"start"`}POSTAPIJSON输入请求:{"Start":ISODate("2013-10-01T00:00:00.000Z")}我将输入JSON请求转换为Golang结构的代码:funcmyPostApi(whttp.ResponseWriter,r*http.Request,dbmongoDB){w.Header().Set("Content-Type","application/jso

elasticsearch - GoLang 从 Elasticsearch 结果中解码 JSON

我有从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