一、elasticserch请求规范 RESTful

1.请求连接url:http://192.168.10.11:9200/<index>/<type>/[<id>]

ip是es服务ip,端口根据服务器默认或其他,

index相当于 mysql的数据库

type相当于mysql的表

id相当于行主键id,id是可选的,es会自动生成

2.请求RestFull风格:http请求(head头:Content-Type:application/json),发送方法

查询: get

新增:put、post

修改:put、post

删除:delete

3.比如我们要存储学生的信息到elasticsearch中,

index----school_1 学校

type----class_1 班级

id---- 学生id

学生信息json格式:

{
    "name":"somebody",
    "age":18,
    "like":"xoxo",
}

http://192.168.10.11:9200/school_1/class_1/1 GET请求:查询某学校某班级一个id为1的学生信息

http://192.168.10.11:9200/school_1/class_1/_search GET请求:查询某学校某班级所有学生的信息

http://192.168.10.11:9200/school_1/class_1/n PUT请求:新增学生 ,需要body传新增的json数据

修改也可以用新增方式请求将数据覆盖达到修改效果。

http://192.168.10.11:9200/school_1/class_1/1 DELETE请求; 删掉一个数据

http://192.168.10.11:9200/school_1/class_1/_search GET请求:查看某学校某班级所有学生数据

http://192.168.10.11:9200/school_1/class_1/1?_source=name,like  GET请求:查看某个学生名称和喜好

二、elasticsearch返回结果集,各字段代表什么意思

获得的结果需要从这个结构中层层解析获得

"took" : 48,  -------------------->  took表示Elasticsearch执行搜索所用的时间,单位是毫秒。

"timed_out" : false,  --------------->  指示搜索是否超时

"_shards" : { --------------------->  _shards 指示搜索了多少分片,以及搜索成功和失败的分片的计数

    "total" : 1,

    "successful" : 1,

    "skipped" : 0,

    "failed" : 0 

}

"hits" : { ------------------------>  hits 用来实际搜索结果集

      "total" :  -------------------->  本次搜索返回多少条结果

      "max_score": ---------------->  本次搜索中 最大的相关分数

      "hits": [---------------------->  默认查询前10数据  查询完整的数据  以_source降序排序

          {

               "_index": "attacker_log_2019-10",  -------->  索引

               "_type": ---------------------------->  属性

               "_id": ------------------------------>  索引数据id

               "_score":

               "_source": {  ------------------------>  结果原数据

                      "xxxxxx": 

                      "yyyyyy":

                      "zzzzzz": 

               }

          }

      "aggerations": ---------------------------->  查询分类聚合数据

三、golang连接elasticsearch

我服务器装的elasticsearch 版本是 7.x.x版本,所以包是对应v7版本


github.com/olivere/elastic/v7


如下,获得连接服务器的 client实例

package es

import (
	"context"
	"github.com/olivere/elastic/v7"
)

var Client *elastic.Client
var host = "http://192.168.10.11:9200"

//初始化
func InitClient() {
	//errorlog := log.New(os.Stdout, "APP", log.LstdFlags)
	var err error
	//初始化客户端
	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 %s\n", code, info.Version.Number)
	//获取服务端版本号
	_, err = Client.ElasticsearchVersion(host)
	if err != nil {
		panic(err)
	}
	//fmt.Printf("Elasticsearch version %s\n", esversion)
}

四、golang调用进行增删改查

1.定义 数据结构

package main

import (
	"context"
	"encoding/json"
	"es/es"
	"fmt"
	"github.com/olivere/elastic/v7"
	"reflect"
)

var client *elastic.Client
var Index  = "school_1"
var Type  = "class_1"

func init()  {
	es.InitClient() //初始化client
	client = es.Client
}

//Person 数据结构体
type Person struct {
	Name string `json:"name"`
	Age int `json:"age"`
	Like string `json:"like"`
}

2.新增数据

新增的数据可以以结构体方式和json字符串方式,BodyJosn()方法会转接数据

//添加一条数据
func addPerson() {
	//添加数可以用结构体方式和 json字符串方式
	p := Person{"张良",25,"围棋"}
	//p := `{"name":"张良","age":25,"like":"围棋"}`
	put,err := client.Index().Index(Index).Type(Type).Id("1").BodyJson(p).Do(context.Background())
	if err != nil {
		panic(err)
	}
	fmt.Printf("indexed %s --- index %s --- type %s \n",put.Id,put.Index,put.Type)
}
func main() {
	addPerson()
}

es的head连接不上 如何连接es_elastic

 3.根据id获取一条数据

//查找一条数据
func gets() {
	//通过id查找
	get1, err := client.Get().Index(Index).Type(Type).Id("1").Do(context.Background())
	if err != nil {
		panic(err)
	}
	if get1.Found {
		//fmt.Printf("Got document %s in version %d from index %s, type %s\n", get1.Id, get1.Version, get1.Index, get1.Type)
		var p Person
		err := json.Unmarshal(get1.Source, &p) //将结果集中的数据映射到结构体中
		if err != nil {
			fmt.Println(err)
		}
		fmt.Println(p)
		//fmt.Println(string(get1.Source))
	}
}
func main() {
	gets()
}

4.修改一条数据

//修改
func updateP() {
	up,err := client.Update().Index(Index).Type(Type).Id("1").
		Doc(map[string]interface{}{"name":"史泰龙"}).
		Do(context.Background())
	if err != nil {
		panic(err)
	}
	fmt.Printf("indexed %s --- index %s --- type %s \n",up.Id,up.Index,up.Type)
}

func main() {
	updateP()
}

5.删除一条数据

//删除一条
func deleteP() {
	d,err := client.Delete().
		Index(Index).Type(Type).Id("1").Do(context.Background())
	if err != nil {
		panic(err)
	}
	fmt.Printf("indexed %s --- index %s --- type %s \n",d.Id,d.Index,d.Type)
}

func main() {
	deleteP()
}

6.查询所有数据

//查询所有数据
func query2() {
	var res *elastic.SearchResult
	var err error
	res,err = client.Search(Index).Type(Type).Do(context.Background())
	if err != nil {
		panic(err)
	}
	num := res.Hits.TotalHits.Value //搜索到结果总条数
	if num > 0 {
		for _,hit := range res.Hits.Hits {
			var p Person
			err = json.Unmarshal(hit.Source,&p)
			if err != nil {
				panic(err)
			}
			fmt.Printf(" name : %s --- age : %d --- like : %s",p.Name,p.Age,p.Like)
		}
	}
}
func main() {
	query2()
}

7,条件查询,某个字段包含某个词的数据

//条件查询多条数据,某个字段包含某个词
func query3() {
	var res *elastic.SearchResult
	var err error
	q := elastic.NewQueryStringQuery("name:张")
	res,err = client.Search(Index).Type(Type).Query(q).Do(context.Background())
	if err != nil {
		panic(err)
	}
	num := res.Hits.TotalHits.Value //搜索到结果总条数
	if num > 0 {
		for _,hit := range res.Hits.Hits {
			var p Person
			err = json.Unmarshal(hit.Source,&p)
			if err != nil {
				panic(err)
			}
			fmt.Printf(" name : %s --- age %d \n",p.Name,p.Age)
		}
	}
}
func main() {
	query3()
}

8.多条件查询,某字段包含某词且年龄小于32的

//带条件的查询多条数据
func query4() {
	var res *elastic.SearchResult
	var err error
	q := elastic.NewBoolQuery()
	q.Must(elastic.NewMatchQuery("name","张"))
	q.Filter(elastic.NewRangeQuery("age").Lt(32)) //小于30岁
	res,err = client.Search(Index).Type(Type).Query(q).Do(context.Background())
	if err != nil {
		panic(err)
	}
	num := res.Hits.TotalHits.Value //搜索到结果总条数
	if num > 0 {
		for _,hit := range res.Hits.Hits {
			var p Person
			err = json.Unmarshal(hit.Source,&p)
			if err != nil {
				panic(err)
			}
			fmt.Printf(" name : %s --- age %d \n",p.Name,p.Age)
		}
	}
}

func main() {
	query4()
}

9.某字段包含某词的

//查询某字段中包含 xxx词的数据
func query5() {
	var res *elastic.SearchResult
	var err error
	q := elastic.NewMatchPhraseQuery("name","仪")
	res,err = client.Search(Index).Type(Type).Query(q).Do(context.Background())
	if err != nil {
		panic(err)
	}
	num := res.Hits.TotalHits.Value //搜索到结果总条数
	if num > 0 {
		for _,hit := range res.Hits.Hits {
			var p Person
			err = json.Unmarshal(hit.Source,&p)
			if err != nil {
				panic(err)
			}
			fmt.Printf(" name : %s --- age %d \n",p.Name,p.Age)
		}
	}
}

func main() {
	query5()
}

10,分页查询

//分页
func query6(size int,page int) {
	var res *elastic.SearchResult
	var err error
	res,err = client.Search(Index).Type(Type).Size(size).From((page-1)*size).Do(context.Background())
	if err != nil {
		panic(err)
	}
	num := res.Hits.TotalHits.Value //搜索到结果总条数
	if num > 0 {
		for _,hit := range res.Hits.Hits {
			var p Person
			err = json.Unmarshal(hit.Source,&p)
			if err != nil {
				panic(err)
			}
			fmt.Printf(" name : %s --- age %d \n",p.Name,p.Age)
		}
	}
}

func main() {
	query6(2,1)
}