关于ElasticSearch,请问屏幕前的你了解多少?

前言: 鄙人作为一位学习ElasticSearch的新手,希望通过此篇学习到更多有关ElasticSearch的知识


提示:以下是本篇文章正文内容,下面案例可供参考

1. 初识 ElasticSearch

1.1-基于数据库查询的问题

在这里插入图片描述

1.2-倒排索引

倒排索引: 将文档进行分词,形成词条和id的对应关系即为反向索引。
以唐诗为例,所处包含“前”的诗句
正向索引:由《静夜思》–>窗前明月光—>“前”字
反向索引:“前”字–>窗前明月光–>《静夜思》
反向索引的实现就是对诗句进行分词,分成单个的词,由词推据,即为反向索引
“床前明月光”–> 分词
将一段文本按照一定的规则,拆分为不同的词条(term)
在这里插入图片描述
在这里插入图片描述

1.3-ES存储和查询的原理

index(索引):相当于mysql的库
映射:相当于mysql 的表结构
document(文档):相当于mysql的表中的数据
数据库查询存在的问题:

  1. 性能低:使用模糊查询,左边有通配符,不会走索引,会全表扫描,性能低
  2. 功能弱:如果以”华为手机“作为条件,查询不出来数据
    Es使用倒排索引,对title 进行分词
    在这里插入图片描述
  3. 使用“手机”作为关键字查询
    生成的倒排索引中,词条会排序,形成一颗树形结构,提升词条的查询速度
  4. 使用“华为手机”作为关键字查询
    华为:1,3
    手机:1,2,3
    在这里插入图片描述

1.4-ES概念详解

•ElasticSearch是一个基于Lucene的搜索服务器

在这里插入图片描述
•是一个分布式、高扩展、高实时的搜索与数据分析引擎
•基于RESTful web接口
•Elasticsearch是用Java语言开发的,并作为Apache许可条款下的开放源码发布,是一种流行的企业级
搜索引擎
•官网:https://www.elastic.co/

应用场景
•搜索:海量数据的查询
•日志数据分析
•实时数据分析

2-安装ElasticSearch

2.1-ES安装

参见官网ElasticSearch-ES的安装
查看elastic是否启动

ps -ef|grep elastic

2.2-ES辅助工具安装

参见官网ElasticSearch-ES的安装
后台启动

nohup ../bin/kibana &

3-ElasticSearch核心概念

索引(index)

ElasticSearch存储数据的地方,可以理解成关系型数据库中的数据库概念。

映射(mapping)

mapping定义了每个字段的类型、字段所使用的分词器等。相当于关系型数据库中的表结构。

文档(document)

Elasticsearch中的最小数据单元,常以json格式显示。一个document相当于关系型数据库中的一行数
据。

倒排索引

一个倒排索引由文档中所有不重复词的列表构成,对于其中每个词,对应一个包含它的文档id列表。

类型(type)

一种type就像一类表。如用户表、角色表等。在Elasticsearch7.X默认type为_doc

\- ES 5.x中一个index可以有多种type。 
\- ES 6.x中一个index只能有一种type。
\- ES 7.x以后,将逐步移除type这个概念,现在的操作已经不再使用,默认_doc

4-脚本操作ES

4.1-RESTful风格介绍

1.ST(Representational State Transfer),表述性状态转移,是一组架构约束条件和原则。满足这些
约束条件和原则的应用程序或设计就是RESTful。就是一种定义接口的规范。
2.基于HTTP。
3.使用XML格式定义或JSON格式定义。
4.每一个URI代表1种资源。
5.客户端使用GET、POST、PUT、DELETE 4个表示操作方式的动词对服务端资源进行操作:
GET:用来获取资源
POST:用来新建资源(也可以用于更新资源)
PUT:用来更新资源
DELETE:用来删除资源
在这里插入图片描述

4.2-操作索引

PUT

http://ip:端口/索引名称

查询

GET http://ip:端口/索引名称 
# 查询单个索引信息 GET http://ip:端口/索引名称1,索引名称2...
# 查询多个索引信息 GET http://ip:端口/_all # 查询所有索引信息

删除索引

DELETE http://ip:端口/索引名称

关闭、打开索引

POST http://ip:端口/索引名称/_close POST http://ip:端口/索引名称/_open

4.3-ES数据类型

1. 简单数据类型

  • 字符串 聚合:
  • 相当于mysql 中的sum(求和)
 text:会分词,不支持聚合
 keyword:不会分词,将全部内容作为一个词条,支持聚合
  • 数值
  • 布尔:boolean
  • 二进制:binary
  • 范围类型
integer_range, float_range, long_range, double_range, date_range
  • 日期:date

2. 复杂数据类型

  • 数组:[ ] Nested: nested (for arrays of JSON objects 数组类型的JSON对象)
  • 对象:{ } Object: object(for single JSON objects 单个JSON对象)

4.4-操作映射

PUT person 
GET person 
#添加映射
 PUT /person/_mapping 
 { 
 "properties":{
  "name":{ 
     "type":"text" 
  },
  "age":{ 
  "type":"integer"
  }
 } 
}

创建索引并添加映射

#创建索引并添加映射
 PUT /person1
{ 
  "mappings": {
   "properties": {
    "name": { 
     "type": "text" 
     },"age": {
      "type": "integer"
      } 
    } 
  } 
}
GET person1/_mapping

添加字段

#添加字段
 PUT /person1/_mapping
 { 
 "properties": {
     "name": { 
       "type": "text"
     },
     "age": {
         "type": "integer"
     } 
   } 
 }

4.5-操作文档

  • 添加文档,指定id
POST /person1/_doc/2 
 { 
   "name":"张三", 
   "age":18, 
   "address":"北京"
 }
 GET /person1/_doc/1
  • 添加文档,不指定id
#添加文档,不指定id
 POST /person1/_doc/
  { 
  "name":"张三",
   "age":18, 
   "address":"北京" 
  }
#查询所有文档
 GET /person1/_search
#删除指定id文档 
 DELETE /person1/_doc/1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值