码农笔录博客源码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

138 lines
3.0 KiB

пре 6 година
package utils
import (
"beeblog/models"
"context"
"fmt"
пре 3 година
beego "github.com/beego/beego/v2/server/web"
пре 6 година
"github.com/olivere/elastic"
пре 3 година
"log"
"os"
пре 6 година
"reflect"
"strconv"
пре 3 година
"time"
пре 6 година
)
пре 4 година
пре 6 година
var client *elastic.Client
пре 4 година
пре 6 година
const mapping = `
{
"settings":{
"number_of_shards": 1,
"number_of_replicas": 0
},
"mappings":{
"beeblog":{
"properties":{
"UserId":{
"type":"long"
},
"BlogHtml":{
"type":"text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_smart"
},
"Ctime":{
"type":"date"
},
"Title":{
"type":"text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_smart"
},
"Browses":{
"type":"long"
}
}
}
}
}`
пре 3 година
func init() {
host, _ := beego.AppConfig.String("eshost")
var err error
client, err = elastic.NewClient(
elastic.SetURL(host),
elastic.SetSniff(false),
elastic.SetHealthcheckInterval(10*time.Second),
elastic.SetGzip(true),
elastic.SetErrorLog(log.New(os.Stderr, "ELASTIC ", log.LstdFlags)),
elastic.SetInfoLog(log.New(os.Stdout, "", log.LstdFlags)))
if err != nil {
panic(err)
}
}
пре 6 година
пре 4 година
func Index() {
пре 6 година
ctx := context.Background()
exists, err := client.IndexExists("beeblog").Do(ctx)
if err != nil {
panic(err)
}
if !exists {
createIndex, err := client.CreateIndex("beeblog").BodyString(mapping).Do(ctx)
if err != nil {
panic(err)
}
if !createIndex.Acknowledged {
fmt.Println("请求未被接收到")
}
fmt.Println(createIndex)
} else {
fmt.Println("已经存在beeblog索引")
}
}
пре 4 година
func ESSave(blog *models.Blog) {
пре 6 година
ctx := context.Background()
пре 4 година
id := strconv.FormatInt(blog.Id, 10)
пре 6 година
_, err := client.Index().Index("beeblog").Type("beeblog").Id(id).BodyJson(blog).Do(ctx)
пре 6 година
if err != nil {
пре 6 година
fmt.Println(err)
return
пре 6 година
}
}
пре 4 година
пре 6 година
//删除
func ESDelete(id string) {
пре 6 година
_, err := client.Delete().Index("beeblog").
пре 6 година
Type("beeblog").
Id(id).
Do(context.Background())
if err != nil {
println(err.Error())
return
}
}
пре 4 година
func Search(key string) (*models.Blog, error) {
пре 6 година
ctx := context.Background()
пре 4 година
query := elastic.NewMultiMatchQuery(key, "Title", "BlogHtml")
пре 6 година
searchResult, err := client.Search().
пре 4 година
Index("beeblog"). // 指定index,返回一个*SearchService对象
пре 6 година
//Type("beeblog").
пре 4 година
Query(query). // 设置查询体,返回同一个*SearchService对象
пре 6 година
//Sort("user", true). // 按照user升序排列
//From(0).Size(10). // 从第一条数据,找十条,即0-9
пре 4 година
Pretty(true). // 使查询request和返回的结果格式美观
Do(ctx) // 返回一个*SearchResult
пре 6 година
if err != nil {
пре 4 година
println("search error", err.Error())
return nil, err
пре 6 година
}
fmt.Printf("找到 [%d] 组tweets\n", searchResult.Hits.TotalHits)
// 查看匹配到多少组数据
fmt.Printf("找到 [%d] 组tweets\n", searchResult.TotalHits())
var typ models.Blog
for _, item := range searchResult.Each(reflect.TypeOf(typ)) { //从搜索结果中取数据的方法
t := item.(models.Blog)
fmt.Printf("%#v\n", t)
пре 4 година
return &t, nil
пре 6 година
}
if err != nil {
panic(err)
}
пре 4 година
return nil, nil
}