当前位置: 首页 > news >正文

谷粒商城实战笔记-105~107-全文检索-ElasticSearch-入门

文章目录

  • 一,105-全文检索-ElasticSearch-入门-_cat
  • 二,106-全文检索-ElasticSearch-入门-put&post新增数据
  • 三,107-全文检索-ElasticSearch-入门-get查询数据&乐观锁字段
      • 1,过时的乐观锁-version
      • 2,Elasticsearch7的乐观锁

这篇内容是使用kibana学习elasticsearch的使用。

一,105-全文检索-ElasticSearch-入门-_cat

在kibana中打开devtools界面。

在这里插入图片描述

在代码的下面界面的左侧区域使用elasticsearch的API完成对elasticsearch的操作。

在这里插入图片描述

在DevTools左侧编辑界面输入命令,点击右侧三角按钮发出请求。
在这里插入图片描述

GET /_cat/nodes:查看所有节点
GET /_cat/health:查看 es 健康状况
GET /_cat/master:查看主节点
GET /_cat/indices:查看所有索引 

在这里插入图片描述

  1. GET /_cat/nodes

    • 这个API端点用于列出Elasticsearch集群中的所有节点。它会返回节点的名称、角色、主机地址、版本等信息。
      在这里插入图片描述
  2. GET /_cat/health

    • 这个API端点用于显示集群的健康状况。它会返回集群的总体状态(如green、yellow或red),以及关于分片和节点的详细信息。
  3. GET /_cat/master

    • 这个API端点用于显示当前集群的主节点信息。主节点负责管理集群状态和分片的分配。
  4. GET /_cat/indices

    • 这个API端点用于列出集群中所有的索引。它会返回索引的名称、文档数量、数据大小、索引状态等信息。
      在这里插入图片描述

要使用这些API,需要通过HTTP客户端(如curl、Postman或任何其他HTTP工具)向Elasticsearch服务发送GET请求。例如,使用curl工具,可以这样发送请求:

curl -X GET "localhost:9200/_cat/nodes"

会返回Elasticsearch集群中所有节点的信息。注意,需要将localhost:9200替换为实际的Elasticsearch服务地址和端口。

二,106-全文检索-ElasticSearch-入门-put&post新增数据

保存一个数据,保存在哪个索引的哪个类型下,指定用哪个唯一标识。

// 在 customer 索引下保存 1 号数据为
POST customer/_doc/1
{"name": "John Doe"
}
  • customer,索引名称
  • _doc,type名称,索引下最多有一个type

响应结果如下。

在这里插入图片描述

注意,如果没有对应的索引,会自动创建索引,然后在索引下插入数据。比如调用这个API向customer索引插入一条数据,虽然没有提前创建customer索引,但是服务端会先创建索引,然后在这个索引下创建文档。

PUT 和 POST 的区别:

  • POST 可以新增可以修改。如果不指定 id,会自动生成 id。指定 id 就会修改这个数据,并新增版本号
  • PUT 可以新增可以修改。PUT 必须指定 id;由于 PUT 需要指定 id,我们一般都用来做修改
    操作,不指定 id 会报错。

三,107-全文检索-ElasticSearch-入门-get查询数据&乐观锁字段

查询一个id为1的文档。

GET customer/_doc/1

结果如下。

在这里插入图片描述

  • "_index" : "customer":这表示查询结果来自名为"customer"的索引。

  • "_type" : "_doc":这是文档的类型,在Elasticsearch 7.x版本之后,文档类型被废弃,统一使用_doc作为文档类型。

  • "_id" : "1":这是文档的唯一标识符,在Elasticsearch中,每个文档都有一个唯一的ID。

  • "_version" : 5:这表示文档的版本号,Elasticsearch使用版本号来处理文档更新和删除操作。

  • "_seq_no" : 8:这是文档的序列号,用于追踪文档在索引中的顺序。

  • "_primary_term" : 1:这是主分片的任期号,用于处理分片故障和恢复。

  • "found" : true:这表明查询找到了匹配的文档。

  • "_source" : { "name" : "John Doe" }:这是文档的原始数据部分,包含了文档的字段和值。在这个例子中,文档有一个字段name,其值为"John Doe"。

1,过时的乐观锁-version

Elasticsearch6以前的乐观锁是通过版本号(_version)来实现的。

乐观锁是一种并发控制机制,它假设在大多数情况下,多个进程或线程不会同时修改同一数据项。当一个进程或线程想要更新一个文档时,它会带上该文档的当前版本号。

如果在这个进程或线程读取文档之后,有其他进程或线程更新了该文档,导致版本号发生变化,那么Elasticsearch 会拒绝这个更新请求,并返回一个错误,提示版本冲突。

乐观锁的使用可以防止数据的并发更新导致的数据不一致问题。以下是如何使用Elasticsearch API 来构建一个测试用例的步骤:

  1. 创建索引:首先,你需要创建一个索引来存储文档。

    PUT /my_index
    {"settings": {"index": {"number_of_shards": 1,"number_of_replicas": 0}}
    }
    
  2. 索引文档:然后,索引一个文档,并记录下返回的版本号。

    POST /my_index/_doc/1
    {"name": "John Doe"
    }
    

    返回结果中会包含文档的版本号。

  3. 读取文档:读取文档以获取其当前版本号。

    GET /my_index/_doc/1
    

    返回结果中会包含文档的当前版本号。

  4. 模拟并发更新:在两个不同的会话或线程中,使用相同的版本号尝试更新同一个文档。

    会话1:

    POST /my_index/_update/1?version=1
    {"doc": {"name": "Jane Doe"}
    }
    

    会话2(几乎同时):

      POST /my_index/_update/1?version=1{"doc": {"name": "Alice Smith"}}
    

注意,如果es版本是7及更高版本,使用version作为乐观锁会报如下错误。

在这里插入图片描述

  1. 处理版本冲突:Elasticsearch 会处理这两个更新请求,但是只有一个会成功,另一个会因为版本冲突而失败。

    成功更新的会话将返回一个成功的状态,而失败的会话将返回一个错误,例如:

    {"error": {"root_cause": [{"type": "version_conflict_engine_exception","reason": "[my_index][1]: version conflict, current version [2] is different than the one provided [1]","index_uuid": "...","shard": "0","index": "my_index"}],"type": "version_conflict_engine_exception","reason": "[my_index][1]: version conflict, current version [2] is different than the one provided [1]","index_uuid": "...","shard": "0","index": "my_index"},"status": 409
    }
    

2,Elasticsearch7的乐观锁

Elasticsearch7已经引入了更先进的并发控制机制,使用if_seq_noif_primary_term参数进行文档更新和删除操作。

if_seq_noif_primary_term参数允许用户在执行更新或删除操作时指定期望的序列号和主分片任期号。

如果指定的序列号和任期号与当前文档的序列号和任期号不匹配,Elasticsearch将拒绝操作并返回错误。
以下是使用if_seq_noif_primary_term参数构建测试用例的步骤:

  1. 索引文档:首先,索引一个文档。

    POST /my_index/_doc/1
    {"name": "John Doe"
    }
    
  2. 获取文档的序列号和任期号:通过获取文档的详细信息来获取序列号(_seq_no)和主分片任期号(_primary_term)。

    GET /my_index/_doc/1
    
  3. 尝试更新文档:使用获取到的序列号和任期号尝试更新文档。

    POST /my_index/_update/1?if_seq_no=1&if_primary_term=1
    {"doc": {"name": "Jane Doe"}
    }
    

    在这个例子中,我们假设文档的初始序列号是1,任期号也是1。

  4. 并发更新:在另一个会话中,尝试使用相同的序列号和任期号更新同一个文档。

    POST /my_index/_update/1?if_seq_no=1&if_primary_term=1
    {"doc": {"name": "Alice Smith"}
    }
    
  5. 处理并发冲突:如果第一个更新操作成功,第二个更新操作将因为序列号或任期号不匹配而失败。

    失败的更新操作将返回一个错误,例如:

    {"error": {"root_cause": [{"type": "version_conflict_engine_exception","reason": "[my_index][1]: version conflict, required seq_no [1], primary term [1]. current document has seq_no [2] and primary term [1]"}],"type": "version_conflict_engine_exception","reason": "[my_index][1]: version conflict, required seq_no [1], primary term [1]. current document has seq_no [2] and primary term [1]"},"status": 409
    }
    

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Mac OS平台,利用 gifify 制作gif教程
  • RK3568笔记五十:SPI通信-回环测试
  • vue3表格组件formatter
  • 视频超压缩保持质量 ffmpeg
  • 该设备几乎不消耗任何功率就能发射无线电波,且不违反物理定律
  • 掌握Python爬虫中的BeautifulSoup4:从环境搭建到实战演示
  • conda操作总结
  • 【数据湖与数据仓库】数据湖与数据仓库的区别与应用
  • flutter 使用正则表达式进行日期、时间格式化
  • ETL工程师角度下的SQL优化
  • 【C++11】解锁C++11新纪元:深入探索Lambda表达式的奥秘
  • Unity强化工程 之 音效
  • SAP-PLM创建物料主数据接口
  • JavaScript和vue实现左右两栏,中间拖动按钮可以拖动左右两边的宽度
  • 全排列的 Java 实现
  • 「面试题」如何实现一个圣杯布局?
  • 【刷算法】从上往下打印二叉树
  • Apache Zeppelin在Apache Trafodion上的可视化
  • C++类中的特殊成员函数
  • Computed property XXX was assigned to but it has no setter
  • emacs初体验
  • Fundebug计费标准解释:事件数是如何定义的?
  • gitlab-ci配置详解(一)
  • Gradle 5.0 正式版发布
  • Java超时控制的实现
  • Node.js 新计划:使用 V8 snapshot 将启动速度提升 8 倍
  • Perseus-BERT——业内性能极致优化的BERT训练方案
  • Python学习之路16-使用API
  • spring boot下thymeleaf全局静态变量配置
  • 百度贴吧爬虫node+vue baidu_tieba_crawler
  • 测试开发系类之接口自动化测试
  • 官方解决所有 npm 全局安装权限问题
  • 记一次用 NodeJs 实现模拟登录的思路
  • 简单基于spring的redis配置(单机和集群模式)
  • 腾讯优测优分享 | 你是否体验过Android手机插入耳机后仍外放的尴尬?
  • 在Mac OS X上安装 Ruby运行环境
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • 关于Kubernetes Dashboard漏洞CVE-2018-18264的修复公告
  • ‌JavaScript 数据类型转换
  • #HarmonyOS:基础语法
  • #QT 笔记一
  • #我与Java虚拟机的故事#连载01:人在JVM,身不由己
  • $NOIp2018$劝退记
  • (02)vite环境变量配置
  • (31)对象的克隆
  • (html转换)StringEscapeUtils类的转义与反转义方法
  • (八)Flink Join 连接
  • (第30天)二叉树阶段总结
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (接口封装)
  • (删)Java线程同步实现一:synchronzied和wait()/notify()
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • .bat批处理(六):替换字符串中匹配的子串