Golang操做elasticsearch(一)

Golang操做elasticsearch

  • 使用第三方包:olivere github。總結一下olivere操做ES的經常使用功能,方便查閱。
  • 說明:如下例子用到的es index:"test", es type:"test", es address: "http://10.1.1.1:9200"
  1. 新建es clientgit

    func ESClient() (client *elastic.Client,err error){
        file := "./log.log"
        logFile, _ := os.OpenFile(file, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0766) // 應該判斷error,此處簡略
        cfg := []elastic.ClientOptionFunc{
            elastic.SetURL("http://10.1.1.1:9200"),
            elastic.SetSniff(false),
            elastic.SetInfoLog(log.New(logFile, "ES-INFO: ", 0)),
            elastic.SetTraceLog(log.New(logFile, "ES-TRACE: ", 0)),
            elastic.SetErrorLog(log.New(logFile, "ES-ERROR: ", 0)),
        }
        client,err =elastic.NewClient(cfg ...)
        return
    }
  2. 查看某文檔是否存在,給定文檔ID查詢github

    func isExists(id string)bool{
        client,_ := ESClient()
        defer client.Stop()
        exist,_ := client.Exists().Index("test").Type("test").Id(id).Do(context.Background())
        if !exist{
            log.Println("ID may be incorrect! ",id)
            return false
        }
        return true
    }
  3. 獲取某文檔的內容golang

    func(doc *myDocument) Get(id string){
        client ,_:= ESClient()
        defer client.Stop() 
        if !isExists(id){
            return
        }
        esResponse,err := client.Get().Index("test").Type("test").Id(id).Do(context.Background())
        if err != nil {
            // Handle Error
            return
        }
        json.Unmarshal(*esResponse.Source,&doc)
    }
  4. 新增文檔json

    func(doc *myDocument) Add(id string){
        client ,_:= ESClient()
        defer client.Stop() 
        if !isExists(id){
            return
        }
        client.Index().Index("test").Type("test").Id(id).BodyJson(doc).Do(context.Background())
    }
  5. 批量新增app

    func BulkAdd(docs []myDocument){
        bulkRequest := seriesClient.Bulk()
        client ,_:= ESClient()
        defer client.Stop()
        for _,doc := range docs{
            esRequest := elastic.NewBulkIndexRequest().Index("test").Type("test").Id(id).Doc(doc)
            bulkRequest = bulkRequest.Add(esRequest)
        }
        bulkRequest.Do(context.Background())
    }
  6. 更新文檔elasticsearch

    func Update(updateField *map[string]interface{},id string){
        client ,_:= ESClient()
        defer client.Stop()
        if !isExists(id){
            return
        }
        _,err:=client.Update().Index("test").Type("test").Id(id).Doc(updateField).Do(context.Background())
        if err != nil{
            //Handle Error
        }
    }
  7. 刪除文檔code

    func Delete(id string){
        client ,_:= ESClient()
        defer client.Stop()
        if !isExists(id){
            return
        }
        _,err:=client.Delete().Index("test").Type("test").Id(id).Do(context.Background())
        if err != nil{
            //Handle Error
        }
    }
  8. 搜索文檔(搜索是ES很是引覺得傲的功能,如下示例是相對複雜的查詢條件,需將查詢結果排序,按頁返回)排序

    func Search(criteria *SearchCriteria)(docs []myDocument){
        client ,_:= ESClient()
        defer client.Stop()
        query := elastic.NewBoolQuery()
        query = query.Must(elastic.NewTermQuery("category",criteria.Category))
        query=query.Must(elastic.NewMatchQuery("title",criteria.Title))
        query=query.Must(elastic.NewRangeQuery("update_timestamp").Gte(criteria.UpdateTime))
        esResponse,_ :=client.Search().Index("test").Type("test").
            Query(query).Sort(criteria.Sort,criteria.Order=="ASC"||criteria.Order=="asc").
            From(criteria.Offset).Size(criteria.Limit).Do(context.Background())
        for _,value:= range esResponse.Hits.Hits{
            var doc *myDocument
            json.Unmarshal(*value.Source,&doc)
            docs = append(docs,doc)
        }
        return
    }
    
    type SearchCriteria struct{
        Category string `json:"category"`
        Limit int `json:"limit"`
        Offset int `json:"offset"`
        Title string `json:"title"`
        UpdateTime int64 `json:"update_timestamp"`
        Order string `json:"order"`
        Sort string `json:"sort"`
    }
相關文章
相關標籤/搜索