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

news2024/9/21 4:36:30

文章目录

  • 一,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
    }
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1973413.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深入源码P3C-PMD:启动源码(2)

下面我们开始从启动探寻 PMD 的源码设计。 pmd 的启动类为 PmdCli,作为命令行的启动器, 其依赖 picocli 作为控制台命令框架。 picocli 官网:https://picocli.info/ Command(name "checksum", mixinStandardHelpOptions true, v…

Golang | Leetcode Golang题解之第316题去除重复字母

题目&#xff1a; 题解&#xff1a; func removeDuplicateLetters(s string) string {left : [26]int{}for _, ch : range s {left[ch-a]}stack : []byte{}inStack : [26]bool{}for i : range s {ch : s[i]if !inStack[ch-a] {for len(stack) > 0 && ch < stack…

谷歌外链的重要性及获取方法!

对于做谷歌seo的人来说&#xff0c;谷歌外链的重要性不言而喻&#xff0c;这是谷歌评估一个网站的重要指标&#xff0c;它们像是网络上的推荐信&#xff0c;可以显著提高你网站的可见度和信誉&#xff0c;这样有利于关键词获取到更好的排名&#xff0c;有作用的外链能显著提升网…

CDO学习

1.备份instie.mdb文件 2.

MySQL:数据类型表的基础操作

目录 1、数据类型 1.1 数值类型 1.2 字符串类型 1.3 日期类型 2、表的基础操作 2.1 选择数据库 2.2 建表 2.3 查看库中所有表 2.4 查看某一表结构 2.5 删表 3、可视化编辑工具 3.1 运行 1、数据类型 1.1 数值类型 bit类型可指定长度&#xff08;如果不写&#xff0c;…

pytorch学习笔记4 tensor变换

View/reshape viewreshape, 新版本 要保证数据总量不变&#xff0c;否则报错Squeeze/unsqueeze 减少维度和增加维度 unsqueeze(n): 如果n是正&#xff0c;在第n位前面插1维&#xff08;size1&#xff09;&#xff0c; 如果n是负&#xff0c;在倒数第|n|位后面插入1维&#xf…

MySQL数据的增删改查 where 条件查询 基础知识 【3】推荐

操作数据是数据库很重要的一部分&#xff0c;今天整理了下关于MySQL数据库数据的增删改查&#xff0c;包括基础查询、where条件查询、排序、分页、聚合、分组、having以及多表查询&#xff0c;多表查询的直接查询、内连接、外连接以及子查询。方便自己以后查看&#xff0c;也欢…

基于stm32的RTC实时时钟 (HAL)

一&#xff1a;stm32的RTC功能概述 &#xff08;基于stm32f10x&#xff09; 1&#xff1a;绪论 实时时钟是一个独立的计时器&#xff0c;RTC提供一套持续运行的计数器&#xff0c;这些计数器可以配合适合的软件用来提供一个时钟日历功能。计数器的值可以被写入以设置系统当前时…

Linux中栈的大小的修改

目录 1. 使用ulimit命令 2. 修改系统级别的资源限制 3. 修改编译器选项 4. 修改内核参数&#xff08;不常用&#xff09; 5. 修改Makefile文件 检查当前栈大小 在Linux系统中&#xff0c;可以通过几种不同的方法来修改栈的大小。下面是几种常用的方法&#xff1a; 1. 使…

『 Linux 』POSIX 信号量与基于环形队列的生产者消费者模型

文章目录 信号量概念POSIX 信号量基于环形队列的生产者消费者模型基于环形队列的生产者消费者模型编码实现基于环形队列的生产者消费者模型发送任务测试 信号量概念 信号量是一种用于多线程或多进程间同步的机制; 其定义是一个整形变量,本质上信号量可以看成是一个计数器,用来描…

记录一次服务器被(crontab)木马入侵事件

背景&#xff1a;发现平时正常登录的服务器突然进不去&#xff0c;也没明显的错误&#xff0c;重启也登录不了&#xff01; 可能的原因&#xff0c;内存/CPU满了 重启通过用户模式进入&#xff0c;查看进程发现有个定时任务一直在自动创建并执行&#xff08;进程ID一直在变化&a…

机械学习—零基础学习日志(高数19——函数极限理解深化)

零基础为了学人工智能&#xff0c;真的开始复习高数 本次学习笔记&#xff0c;主要讲解函数极限的计算问题。 极限四则运算规则 这里有几个需要注意的地方。函数极限的四则运算&#xff0c;需要知道极限存在才能大胆放心的使用。而且使用超实数的概念会更好帮助我们理解&…

Python 操作PPT幻灯片- 添加、删除、或隐藏幻灯片

PowerPoint文档是商务、教育、创意等各领域常见的用于展示、教育和传达信息的格式。在制作PPT演示文稿时&#xff0c;灵活地操作幻灯片是提高演示效果、优化内容组织的关键步骤。下面将介绍如何使用国产Spire.Presentation for Python库实现添加、删除或隐藏PPT幻灯片。 目录 …

浅谈Java线程池的概念

目录 说明 1.线程池特点 2.线程池的简单示例 2.1 定义一个线程池类&#xff0c;通过创建一个全局的阻塞队列接收任务&#xff0c;线程池类构造方法拿阻塞队列的线程&#xff0c;完成线程的执行。 3. main方法中调用该类&#xff0c;实现线程池的调用 4.效果如下 说明 线程…

MySql Linux 安装

下载 下载后的文件为&#xff1a;mysql-8.4.2-linux-glibc2.28-x86_64.tar.xz 创建用户和用户组 $> groupadd mysql $> useradd -r -g mysql -s /bin/false mysql由于用户仅用于所有权目的&#xff0c;而不是登录目的&#xff0c;因此useradd命令使用 -r和-s /bin/false…

C++笔记之编译过程和面向对象

回顾&#xff1a; “abcd”//数据类型 字符串常量 const char *p"abc"; new STU const char *//8 指针的内存空间 int float 指针的内存空间 p 指针指向的内存空间 "abc" 取决于字符串长度 指针变量的内容一级指针 指针变量的地址二级指针 …

深度学习------权重衰退

目录 使用均方范数作为硬性限制使用均方范数作为柔性限制演示最优解的影响参数更新法则总结高纬线性回归多项式的权重衰退从零开始实现初始化模型参数定义L2范数惩罚定义训练代码实现忽略正则化直接训练使用权重衰减从零开始代码实现 多项式的权重衰退的简洁实现简洁函数代码简…

案例分享|Alluxio在自动驾驶数据闭环中的应用

分享嘉宾&#xff1a; 孙涛 - 中汽创智智驾工具链数据平台开发专家 关于中汽创智&#xff1a; 中汽创智科技有限公司&#xff08;以下简称“中汽创智”&#xff09;由中国一汽、东风公司、南方工业集团、长安汽车和南京江宁经开科技共同出资设立。聚焦智能底盘、新能动力、智…

学习硬件测试04:触摸按键+PWM 驱动蜂鸣器+数码管(P62~P67、P71、P72)

一、触摸按键 1.1理论讲解 1.1.1实验现象 触摸按键 1 单击与长按&#xff0c;控制 LED1&#xff1b;触摸按键 2 单击与长按&#xff0c;控制 LED2;触摸按键 3 单击与长按&#xff0c;控制 LED3;触摸按键 4 单击与长按&#xff0c;控制继电器; 1.1.2硬件电路 是原理图上触摸…

vue3+element-plus实现table表格整列的拖拽

参考文章&#xff1a;https://blog.csdn.net/candy0521/article/details/136470284 一、为防止原文章不见了将参考文章代码拷过来了&#xff08;不好意思&#xff09;&#xff1a;这是参考文章的代码 可直接复制粘贴运行 <template><div class"draggable-table&…