新建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 }
查看某文檔是否存在,給定文檔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 }
獲取某文檔的內容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) }
新增文檔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()) }
批量新增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()) }
更新文檔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 } }
刪除文檔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 } }
搜索文檔(搜索是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"` }