go elsaticsearch demo
- 安装
// elasticsearch sdk
go get -u github.com/elastic/go-elasticsearch/v7
//操作json
go get "github.com/tidwall/gjson"
go get "github.com/aquasecurity/esquery"
- demo
package esexampleimport ("bytes""context""encoding/json""fmt""log""strings""time""github.com/aquasecurity/esquery""github.com/elastic/go-elasticsearch/v7""github.com/elastic/go-elasticsearch/v7/esapi""github.com/gin-gonic/gin""github.com/tidwall/gjson"
)var es_client *elasticsearch.Client// 连接es
func InitEs() {cfg := elasticsearch.Config{Addresses: []string{"http://192.168.214.133:31200",},Username: "elastic",Password: "ellischen",}es_client, _ = elasticsearch.NewClient(cfg)boolquery = &esquery.BoolQuery{}
}// 列出索引
func ListIndex() {res, err := esapi.CatIndicesRequest{Format: "json"}.Do(context.Background(), es_client)if err != nil {return}defer res.Body.Close()fmt.Println(res.String())
}// 查询索引文档个数
func CalculateIndexDocCount() float64 {// res, err := esapi.CountRequest{Index: []string{"ellis"}}.Do(context.Background(), es_client)// if err != nil {// return 0// }// defer res.Body.Close()// var resMap map[string]interface{}// json.NewDecoder(res.Body).Decode(&resMap)// fmt.Printf("resMap: %v\n", resMap["count"])// // fmt.Printf("res.Header: %v\n", res.Header)// // fmt.Println(res.String())// return resMap["count"].(float64)r, err := es_client.Count(es_client.Count.WithIndex("ellis"))if err != nil {fmt.Printf("err: %v\n", err)}var value map[string]interface{}json.NewDecoder(r.Body).Decode(&value)return value["count"].(float64)
}// 插入一个文档
func IndexOneDocument() {//method 1// document := Ellis{Name: "haha"}// data, _ := json.Marshal(document)// req := esapi.IndexRequest{// Index: "ellis",// DocumentID: "3",// Body: strings.NewReader(string(data)),// Refresh: "true",// }// res, err := req.Do(context.TODO(), es_client)// if err != nil {// log.Fatalf("IndexRequest ERROR: %s", err)// }// defer res.Body.Close()// if res.IsError() {// log.Printf("%s ERROR indexing document ID=%d", res.Status(), 3)// } else {// // Deserialize the response into a map.// var resMap map[string]interface{}// if err := json.NewDecoder(res.Body).Decode(&resMap); err != nil {// log.Printf("Error parsing the response body: %s", err)// } else {// log.Printf("\nIndexRequest() RESPONSE:")// // Print the response status and indexed document version.// fmt.Println("Status:", res.Status())// fmt.Println("Result:", resMap["result"])// fmt.Println("Version:", int(resMap["_version"].(float64)))// fmt.Println("resMap:", resMap)// }// }//method 2document := Ellis{Name: "haha"}data, _ := json.Marshal(document)r, err2 := es_client.Index("ellis", strings.NewReader(string(data)), es_client.Index.WithDocumentID("4"))if err2 != nil {fmt.Printf("err2: %v\n", err2)} else {defer r.Body.Close()var value map[string]interface{}json.NewDecoder(r.Body).Decode(&value)vv, _ := json.Marshal(value)fmt.Printf("string(vv): %v\n", string(vv))}
}// 通过ID查询
func GetByID(id string) (value any) {// method 1// r, err := esapi.GetRequest{Index: "ellis", DocumentID: id}.Do(context.Background(), es_client)// if err != nil {// return nil// } else {// defer r.Body.Close()// fmt.Printf("r.String(): %v\n", r.String())// var value interface{}// json.NewDecoder(r.Body).Decode(&value)// fmt.Printf("value: %v\n", value)// return value// }// method 2r, err := es_client.Get("ellis", id, es_client.Get.WithRefresh(true))if err != nil {return nil} else {defer r.Body.Close()var value map[string]interface{}json.NewDecoder(r.Body).Decode(&value)fmt.Printf("value: %v\n", value)// 将value转换成JSONvv, _ := json.Marshal(value)fmt.Printf("string(vv): %v\n", string(vv))return value}
}// 通过DSL查询
func SearchByDSL() {var buf bytes.Bufferquery := map[string]interface{}{"query": map[string]interface{}{"term": map[string]interface{}{"name": "haha",},},}if err := json.NewEncoder(&buf).Encode(query); err != nil {log.Fatalf("Error encoding query: %s", err)}// Perform the search request.res, err := es_client.Search(es_client.Search.WithContext(context.Background()),es_client.Search.WithIndex("ellis"),es_client.Search.WithBody(&buf),es_client.Search.WithTrackTotalHits(true),es_client.Search.WithPretty(),)if err != nil {log.Fatalf("Error getting response: %s", err)}defer res.Body.Close()var r map[string]interface{}if err := json.NewDecoder(res.Body).Decode(&r); err != nil {log.Fatalf("Error parsing the response body: %s", err)}// Print the response status, number of results, and request duration.log.Printf("[%s] %d hits; took: %dms",res.Status(),int(r["hits"].(map[string]interface{})["total"].(map[string]interface{})["value"].(float64)),int(r["took"].(float64)),)// Print the ID and document source for each hit.for _, hit := range r["hits"].(map[string]interface{})["hits"].([]interface{}) {log.Printf(" * ID=%s, %s", hit.(map[string]interface{})["_id"], hit.(map[string]interface{})["_source"])}log.Println(strings.Repeat("=", 37))
}// update by query
func UpdateByQuery() {var buf bytes.Bufferquery := map[string]interface{}{"query": map[string]interface{}{"term": map[string]interface{}{"name": "haha",},},"script": map[string]interface{}{"source": "ctx._source[\"name\"]=params.name","params": map[string]string{"name": "ellis",},"lang": "painless",},}if err := json.NewEncoder(&buf).Encode(query); err != nil {log.Fatalf("Error encoding query: %s", err)}es_client.UpdateByQuery([]string{"ellis"}, es_client.UpdateByQuery.WithBody(&buf))
}// 删除
func Delete() {r, err := es_client.Delete("ellis", "1", es_client.Delete.WithRefresh("true"))if err != nil {fmt.Printf("err: %v\n", err)} else {defer r.Body.Close()var value map[string]interface{}json.NewDecoder(r.Body).Decode(&value)vv, _ := json.Marshal(value)fmt.Printf("string(vv): %v\n", string(vv))}
}// search after
func SearchAfter() {query := `{"query": {"match_all": {}},"sort": [{"_id": {"order": "desc"}}],"size": 1,"search_after":["3"]}`res, err := es_client.Search(es_client.Search.WithIndex("ellis"),es_client.Search.WithBody(strings.NewReader(query)),)if err != nil {log.Fatalf("Error getting response: %s", err)}defer res.Body.Close()var r map[string]interface{}if err := json.NewDecoder(res.Body).Decode(&r); err != nil {log.Fatalf("Error parsing the response body: %s", err)}// Print the response status, number of results, and request duration.log.Printf("[%s] %d hits; took: %dms",res.Status(),int(r["hits"].(map[string]interface{})["total"].(map[string]interface{})["value"].(float64)),int(r["took"].(float64)),)// Print the ID and document source for each hit.for _, hit := range r["hits"].(map[string]interface{})["hits"].([]interface{}) {log.Printf(" * ID=%s, %s", hit.(map[string]interface{})["_id"], hit.(map[string]interface{})["_source"])}log.Println(strings.Repeat("=", 37))
}// scroll 查询
func Scroll() {query := `{"query": {"match_all": {}}}`log.Println("Scrolling the index...")log.Println(strings.Repeat("-", 80))res, err := es_client.Search(es_client.Search.WithBody(strings.NewReader(query)),es_client.Search.WithIndex("ellis"),// es_client.Search.WithSort("_doc"),es_client.Search.WithSize(1),es_client.Search.WithScroll(time.Minute),)if err != nil {fmt.Printf("err: %v\n", err)}var mapvalue map[string]interface{}json.NewDecoder(res.Body).Decode(&mapvalue)value1, _ := json.Marshal(mapvalue)jsonvalue := string(value1)defer res.Body.Close()scrollID := gjson.Get(jsonvalue, "_scroll_id").String()log.Println("ScrollID", scrollID)log.Println("IDs ", gjson.Get(jsonvalue, "hits.hits.#._id"))log.Println(strings.Repeat("-", 80))for _, hit := range mapvalue["hits"].(map[string]interface{})["hits"].([]interface{}) {log.Printf(" * ID=%s, %s", hit.(map[string]interface{})["_id"], hit.(map[string]interface{})["_source"])}for {// Perform the scroll request and pass the scrollID and scroll duration//res, err := es_client.Scroll(es_client.Scroll.WithScrollID(scrollID), es_client.Scroll.WithScroll(time.Minute))if err != nil {log.Fatalf("Error: %s", err)}if res.IsError() {log.Fatalf("Error response: %s", res)}defer res.Body.Close()// Extract the scrollID from responsevar mapvalue map[string]interface{}json.NewDecoder(res.Body).Decode(&mapvalue)value1, _ := json.Marshal(mapvalue)jsonvalue := string(value1)scrollID = gjson.Get(jsonvalue, "_scroll_id").String()hits := gjson.Get(jsonvalue, "hits.hits")if len(hits.Array()) < 1 {log.Println("Finished scrolling")break} else {log.Println("ScrollID", scrollID)log.Println("IDs ", gjson.Get(hits.Raw, "#._id"))log.Println(strings.Repeat("-", 80))for _, v := range hits.Array() {fmt.Printf("v.Raw: %v\n", v.Raw)}}}}var boolquery *esquery.BoolQueryfunc DynamicDSL(c *gin.Context) {var body []Dynamicerr := c.ShouldBindJSON(&body)if err != nil {fmt.Printf("err: %v\n", err)} else {if len(body) > 1 {for _, v := range body {if v.Operation == "=" {boolquery.Should(esquery.Term(v.Field, v.Value))}}boolquery.MinimumShouldMatch(1)} else {for _, v := range body {if v.Operation == "=" {boolquery.Must(esquery.Term(v.Field, v.Value))}}}}res, err := esquery.Search().Query(boolquery).Sort("_id", esquery.OrderDesc).Run(es_client, es_client.Search.WithIndex("ellis"))if err != nil {fmt.Printf("err: %v\n", err)}var value map[string]interface{}json.NewDecoder(res.Body).Decode(&value)b, _ := json.Marshal(value)stringjson := string(b)log.Println("gjson.Get(stringjson, \"hits.hits.#._id\"):\n", gjson.Get(stringjson, "hits.hits.#._id"))defer res.Body.Close()
}func SearchAfterSecond() {res, err := esquery.Search().Query(esquery.MatchAll()).Sort("_id", esquery.OrderDesc).SearchAfter("3").Size(1).Run(es_client, es_client.Search.WithIndex("ellis"))if err != nil {fmt.Printf("err: %v\n", err)}var value map[string]interface{}json.NewDecoder(res.Body).Decode(&value)b, _ := json.Marshal(value)stringjson := string(b)log.Println("gjson.Get(stringjson, \"hits.hits.#._id\"):\n", gjson.Get(stringjson, "hits.hits.#._id"))defer res.Body.Close()
}
https://pkg.go.dev/github.com/okdanta/esquery#section-readme
相关文章:
go elsaticsearch demo
安装 // elasticsearch sdk go get -u github.com/elastic/go-elasticsearch/v7 //操作json go get "github.com/tidwall/gjson" go get "github.com/aquasecurity/esquery"demo package esexampleimport ("bytes""context""en…...
小游戏分发平台如何以技术拓流?
2023年,小游戏的发展将受到多方面的影响,例如新技术的引入、参与小游戏的新玩家以及游戏市场的激烈竞争等。首先,新技术如虚拟现实(VR)、增强现实(AR)和机器人技术都可以带来新颖的游戏体验。其…...
力扣|找出和所对应的两数的下标
从零开始刷力扣(bushi 题目放在这: 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值target的两个整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一…...
使用命令行创建仓库
如果你还没有任何代码,可以通过命令行工具创建一个全新的Git仓库并初始化到本项目仓库中。 git clone https://e.coding.net/***/neurosens.git cd neurosens echo "# neurosens" >> README.md git add README.md git commit -m "first commi…...
ESLint 中的“ space-before-function-paren ”相关报错及其解决方案
ESLint 中的“ space-before-function-paren ”相关报错及其解决方案 出现的问题及其报错: 在 VScode 中,在使用带有 ESLint 工具的项目中,保存会发现报错,并且修改好代码格式后,保存会发现代码格式依然出现问题&…...
docker常用中间件安装
文章目录 1、前言2、中间件安装2.1、mysql2.2、gitlab容器2.3、nacos2.4、redis2.5、xxljob2.6、zipkin2.7、sentinel2.8、seata2.8.1、获取镜像2.8.2、运行容器并获取配置 2.9、rockerMQ2.9.1、rockerMQ-namesrv2.9.2、rockerMQ-broker2.9.3、rockerMQ-console 2.10、jenkins2…...
Camunda 7.x 系列【44】修改流程实例
有道无术,术尚可求,有术无道,止于术。 本系列Spring Boot 版本 2.7.9 本系列Camunda 版本 7.19.0 源码地址:https://gitee.com/pearl-organization/camunda-study-demo 文章目录 1. 概述2. 案例演示2.1 回退2.2 子流程2.3 多实例加签1. 概述 流程模型中,执行活动需要按…...
无频闪护眼灯哪个好?什么是无频闪
随着科技的不断发展,工作时使用电子设备越来越普遍,如何保护我们的眼睛不受蓝光、频闪等危害就变得极其重要了。护眼台灯,顾名思义就是保护眼睛的台灯,其工作原理是在光源处使用特殊的防蓝光灯珠,并通过控制电流的稳定性来达到防频…...
css网格布局
css网格布局 常用属性 display: grid; //开启网格grid-template-columns: 2fr 1fr 1fr 1fr 1fr; //设置多少列每列宽度grid-gap: 10px; // 设置表格之间间距grid-template-rows: 50px 50px 50px 50px; // 设置多少行 每行的高度grid-column : 1 //占据位置 占据1格grid-colu…...
Hadoop -HDFS常用操作指令
1.启动HDFS hadoop/sbin/start-dfs.sh2.关闭 HDFS hadoop/sbin/stop-dfs.sh3. 在HDFS中创建文件夹 #老版本 hadoop fs -mkdir -p path #新版本 hadoop dfs -mkdir -p path4.查看指定目录下内容 hadoop fs -ls [-h] [-R] path hadoop dfs -ls [-h] [-R] ptahpath 指定…...
代码随想录二刷day11
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、力扣20. 有效的括号二、力扣1047. 删除字符串中的所有相邻重复项三、力扣150. 逆波兰表达式求值 前言 一、力扣20. 有效的括号 class Solution {public bo…...
系统架构技能之设计模式-工厂模式
一、开篇 本文主要是讲述设计模式中最经典的创建型模式-工厂模式,本文将会从以下几点对工厂模式进行阐述。 本文将会从上面的四个方面进行详细的讲解和说明,当然会的朋友可以之处我的不足之处,不会的朋友也请我们能够相互学习讨论。 二、摘…...
Docker的基本组成和安装
Docker的基本组成 镜像(image): docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像 > run > tomcat01容器(提供服务) 通过这个镜像可以创建多个容器(最…...
【python爬虫】15.Scrapy框架实战(热门职位爬取)
文章目录 前言明确目标分析过程企业排行榜的公司信息公司详情页面的招聘信息 代码实现创建项目定义item 创建和编写爬虫文件存储文件修改设置 代码实操总结 前言 上一关,我们学习了Scrapy框架,知道了Scrapy爬虫公司的结构和工作原理。 在Scrapy爬虫公司…...
Apinto 网关 V0.14 版本发布,6 大插件更新!
大家好! 距离上次更新已经过去一段时间了,这段日子里我们一直在酝酿新的功能,本次的迭代将给大家带来 6 大插件的更新~一起来看看有哪些变化吧! 新特性 1. 新增 额外参数v2 插件,支持对转发参数进行加密、拼接等操作…...
突破销售瓶颈:亚马逊卖家如何借力TikTok网红营销?
随着社交媒体的崛起,营销方式也在不断变革。TikTok作为一款风靡全球的短视频平台,吸引了数以亿计的用户,成为了品牌宣传和销售的新热点。对于亚马逊卖家而言,通过合理运用TikTok网红营销策略,可以有效提升产品的曝光度…...
JavaWeb之Cookie的简单使用!!!
什么是Cookie Cookie:客户端会话技术,将数据保存到客户端,以后每次请求都携带Cookie数据进行访问 Cookie 数据存放在浏览器端(客户端) 创建Cookie 1.创建Cookie Cookie cookie new Cookie("key","value"); 2.使用response响应…...
16、Flink 的table api与sql之连接外部系统: 读写外部系统的连接器和格式以及Apache Hive示例(6)
Flink 系列文章 1、Flink 部署、概念介绍、source、transformation、sink使用示例、四大基石介绍和示例等系列综合文章链接 13、Flink 的table api与sql的基本概念、通用api介绍及入门示例 14、Flink 的table api与sql之数据类型: 内置数据类型以及它们的属性 15、Flink 的ta…...
6.Redis-hash
hash 哈希类型中的映射关系通常称为field-value,⽤于区分 Redis 整体的键值对(key-value),注意这⾥的value是指field对应的值,不是键(key)对应的值,请注意 value 在不同上下⽂的作⽤…...
点云从入门到精通技术详解100篇-多时相机载激光雷达人工林点云匹配及生长监测(续)
目录 多时相机载激光雷达人工林点云匹配及变化监测 3.1 技术路线 3.2 数据准备 3.3 方法...
HTML 语义化
目录 HTML 语义化HTML5 新特性HTML 语义化的好处语义化标签的使用场景最佳实践 HTML 语义化 HTML5 新特性 标准答案: 语义化标签: <header>:页头<nav>:导航<main>:主要内容<article>&#x…...
Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
前端开发面试题总结-JavaScript篇(一)
文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包(Closure)?闭包有什么应用场景和潜在问题?2.解释 JavaScript 的作用域链(Scope Chain) 二、原型与继承3.原型链是什么?如何实现继承&a…...
JUC笔记(上)-复习 涉及死锁 volatile synchronized CAS 原子操作
一、上下文切换 即使单核CPU也可以进行多线程执行代码,CPU会给每个线程分配CPU时间片来实现这个机制。时间片非常短,所以CPU会不断地切换线程执行,从而让我们感觉多个线程是同时执行的。时间片一般是十几毫秒(ms)。通过时间片分配算法执行。…...
Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信
文章目录 Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信前言一、网络通信基础概念二、服务端与客户端的完整流程图解三、每一步的详细讲解和代码示例1. 创建Socket(服务端和客户端都要)2. 绑定本地地址和端口&#x…...
LCTF液晶可调谐滤波器在多光谱相机捕捉无人机目标检测中的作用
中达瑞和自2005年成立以来,一直在光谱成像领域深度钻研和发展,始终致力于研发高性能、高可靠性的光谱成像相机,为科研院校提供更优的产品和服务。在《低空背景下无人机目标的光谱特征研究及目标检测应用》这篇论文中提到中达瑞和 LCTF 作为多…...
el-amap-bezier-curve运用及线弧度设置
文章目录 简介示例线弧度属性主要弧度相关属性其他相关样式属性完整示例链接简介 el-amap-bezier-curve 是 Vue-Amap 组件库中的一个组件,用于在 高德地图 上绘制贝塞尔曲线。 基本用法属性path定义曲线的路径,可以是多个弧线段的组合。stroke-weight线条的宽度。stroke…...
uniapp获取当前位置和经纬度信息
1.1. 获取当前位置和经纬度信息(需要配置高的SDK) 调用uni-app官方API中的uni.chooseLocation(),即打开地图选择位置。 <button click"getAddress">获取定位</button> const getAddress () > {uni.chooseLocatio…...
开源 vGPU 方案:HAMi,实现细粒度 GPU 切分
本文主要分享一个开源的 GPU 虚拟化方案:HAMi,包括如何安装、配置以及使用。 相比于上一篇分享的 TimeSlicing 方案,HAMi 除了 GPU 共享之外还可以实现 GPU core、memory 得限制,保证共享同一 GPU 的各个 Pod 都能拿到足够的资源。…...
