golang操作elasticsearch的实现

【字号: 日期:2022-09-15浏览:24作者:雯心

1、前提

1.1 docker 安装elasticsearch

查询elasticsearch 版本

docker search elasticsearch

将对应的版本拉到本地

docker.elastic.co/elasticsearch/elasticsearch:7.3.0

创建一个网络

docker network create esnet

启动容器

docker run --name es -p 9200:9200 -p 9300:9300 --network esnet -e 'discovery.type=single-node' bdaab402b220

1.2这里过后就可以去写go代码 为了直观搞了个可视化工具 ElisticHD 这里使用docker 部署

docker run -p 9800:9800 -d --link es:demo --network esnet -e 'discovery.type=single-node' containerize/elastichd

可以试一下界面还是很美观的

golang操作elasticsearch的实现

2、golang 实现elasticsearch 简单的增删改查

直接上代码:

package mainimport ( 'context' 'encoding/json' 'fmt' 'github.com/olivere/elastic/v7' 'reflect')var client *elastic.Clientvar host = 'http://ip:port'type Employee struct { FirstName string `json:'first_name'` LastName string `json:'last_name'` Age int `json:'age'` About string `json:'about'` Interests []string `json:'interests'`}//初始化func init() { //errorlog := log.New(os.Stdout, 'APP', log.LstdFlags) var err error //这个地方有个小坑 不加上elastic.SetSniff(false) 会连接不上 client, err = elastic.NewClient(elastic.SetSniff(false), elastic.SetURL(host)) if err != nil { panic(err) } _,_,err = client.Ping(host).Do(context.Background()) if err != nil { panic(err) } //fmt.Printf('Elasticsearch returned with code %d and version %sn', code, info.Version.Number) _,err = client.ElasticsearchVersion(host) if err != nil { panic(err) } //fmt.Printf('Elasticsearch version %sn', esversion)}/*下面是简单的CURD*///创建func create() { //使用结构体 e1 := Employee{'Jane', 'Smith', 32, 'I like to collect rock albums', []string{'music'}} put1, err := client.Index(). Index('megacorp'). Type('employee'). Id('1'). BodyJson(e1). Do(context.Background()) if err != nil { panic(err) } fmt.Printf('Indexed tweet %s to index s%s, type %sn', put1.Id, put1.Index, put1.Type) //使用字符串 e2 := `{'first_name':'John','last_name':'Smith','age':25,'about':'I love to go rock climbing','interests':['sports','music']}` put2, err := client.Index(). Index('megacorp'). Type('employee'). Id('2'). BodyJson(e2). Do(context.Background()) if err != nil { panic(err) } fmt.Printf('Indexed tweet %s to index s%s, type %sn', put2.Id, put2.Index, put2.Type) e3 := `{'first_name':'Douglas','last_name':'Fir','age':35,'about':'I like to build cabinets','interests':['forestry']}` put3, err := client.Index(). Index('megacorp'). Type('employee'). Id('3'). BodyJson(e3). Do(context.Background()) if err != nil { panic(err) } fmt.Printf('Indexed tweet %s to index s%s, type %sn', put3.Id, put3.Index, put3.Type)}//查找func gets() { //通过id查找 get1, err := client.Get().Index('megacorp').Type('employee').Id('2').Do(context.Background()) if err != nil { panic(err) } if get1.Found { fmt.Printf('Got document %s in version %d from index %s, type %sn', get1.Id, get1.Version, get1.Index, get1.Type) var bb Employee err:=json.Unmarshal(get1.Source,&bb) if err!=nil{ fmt.Println(err) } fmt.Println(bb.FirstName) fmt.Println(string(get1.Source)) }}////删除func delete() { res, err := client.Delete().Index('megacorp'). Type('employee'). Id('1'). Do(context.Background()) if err != nil { println(err.Error()) return } fmt.Printf('delete result %sn', res.Result)}////修改func update() { res, err := client.Update(). Index('megacorp'). Type('employee'). Id('2'). Doc(map[string]interface{}{'age': 88}). Do(context.Background()) if err != nil { println(err.Error()) } fmt.Printf('update age %sn', res.Result)}//////搜索func query() { var res *elastic.SearchResult var err error //取所有 res, err = client.Search('megacorp').Type('employee').Do(context.Background()) printEmployee(res, err) //字段相等 q := elastic.NewQueryStringQuery('last_name:Smith') res, err = client.Search('megacorp').Type('employee').Query(q).Do(context.Background()) if err != nil { println(err.Error()) } printEmployee(res, err) //条件查询 //年龄大于30岁的 boolQ := elastic.NewBoolQuery() boolQ.Must(elastic.NewMatchQuery('last_name', 'smith')) boolQ.Filter(elastic.NewRangeQuery('age').Gt(30)) res, err = client.Search('megacorp').Type('employee').Query(q).Do(context.Background()) printEmployee(res, err) //短语搜索 搜索about字段中有 rock climbing matchPhraseQuery := elastic.NewMatchPhraseQuery('about', 'rock climbing') res, err = client.Search('megacorp').Type('employee').Query(matchPhraseQuery).Do(context.Background()) printEmployee(res, err) //分析 interests aggs := elastic.NewTermsAggregation().Field('interests') res, err = client.Search('megacorp').Type('employee').Aggregation('all_interests', aggs).Do(context.Background()) printEmployee(res, err)}//////简单分页func list(size,page int) { if size < 0 || page < 1 { fmt.Printf('param error') return } res,err := client.Search('megacorp'). Type('employee'). Size(size). From((page-1)*size). Do(context.Background()) printEmployee(res, err)}////打印查询到的Employeefunc printEmployee(res *elastic.SearchResult, err error) { if err != nil { print(err.Error()) return } var typ Employee for _, item := range res.Each(reflect.TypeOf(typ)) { //从搜索结果中取数据的方法 t := item.(Employee) fmt.Printf('%#vn', t) }}func main() { create() delete() update() gets() query() list(2,1)}

有一个小坑要注意在代码中已经注释了,如果没有添加就会有下面错误

no active connection found: no Elasticsearch node available

解决

Docker No Elastic Node Aviable

关闭sniff模式;或者设置es的地址为 publish_address 地址

代码设置 sniff 为false

到此这篇关于golang 操作 elasticsearch的实现的文章就介绍到这了,更多相关golang操作elasticsearch内容请搜索乐呵呵网以前的文章或继续浏览下面的相关文章希望大家以后多多支持乐呵呵网!

标签: Golang
相关文章: