1:简介:

Elasticsearch是一个高度可扩展的、开源的、基于 Lucene 的全文搜索和分析引擎。它允许您快速,近实时地存储,搜索和分析大量数据,并支持多租户。

Elasticsearch也使用Java开发并使用 Lucene 作为其核心来实现所有索引和搜索的功能,但是它的目的是通过简单的 RESTful API 来隐藏 Lucene 的复杂性,从而让全文搜索变得简单。

不过,Elasticsearch 不仅仅是 Lucene 和全文搜索,我们还能这样去描述它:

  • 分布式的实时文件存储,每个字段都被索引并可被搜索
  • 分布式的实时分析搜索引擎
  • 可以扩展到上百台服务器,处理PB级结构化或非结构化数据

而且,所有的这些功能被集成到一个服务里面,你的应用可以通过简单的RESTful API、各种语言的客户端甚至命令行与之交互。

2:版本选择

Elasticsearch 目前有三个常用的稳定的主版本:2.x,5.x,6.x(排除 0.x 和 1.x)。

版本查看:历史版本

你可能会发现没有 3.x 和 4.x,ES 从 2.4.6 直接跳到了 5.0.0。这是为什么?

其实是为了ELK(ElasticSearch, logstash, kibana)技术栈的版本统一,免的给用户带来混乱。

我们知道 elasticsearch,kibana,logstash 都是 Elastic Stack 成员, 而且很多时候都是配合使用,那么为了协同开发,避免造成版本困惑,所以需要统一版本,至少保持在一个主版本号下。

在 Elasticsearch 是 2.x (2.x 的最后一版 2.4.6 的发布时间是 July 25, 2017) 的情况下,kibana 已经是 4.x(Kibana 4.6.5 的发布时间是 July 25, 2017),那么在 kibana 的下一主版本肯定是 5.x 了,所以 Elasticsearch 直接将自己的主版本发布为 5.0.0 了。统一之后,我们选版本就不会犹豫困惑了,我们选定 elasticsearch 的版本后再选择相同版本的 kibana 就行了,不用担忧版本不兼容的问题。

版本选择可以从以下几个方面考虑:

  • 版本问题
    2.x 版本较老,无法体验新功能,且性能不如 5.x。
    6.x 版本有点新,网上资料相对比较少(开发时间充足的可以研究)。
  • 数据迁移
    2.x 版本数据可以直接迁移到 5.x;
    5.X 版本的数据可以直接迁移到 6.x; 但是 2.x 版本数据无法直接迁移到 6.x。
  • 周边工具
    2.x 版本周边工具版本比较混乱;Kibana 等工具的对应版本需要自己查,不好匹配。
    5.x 之后 Kibana 等工具的主版本号进行了统一。
  • Sql 语法支持
    2.x,5.x,6.x 都可以安装 Elasticsearch-sql 插件,使用熟悉的SQL语法查询 Elasticsearch。
    6.3.0 以后内置支持 SQL 模块,这个 SQL 模块是属于 X-Pack 的一部分。

通过以上的版本号了解之后,综合考虑,我起始选择了 elasticsearch 6.4.0版本

3:环境搭建

1:安装ElasticSearch

Elasticsearch5.0之后的版本至少需要Java 8。可通过如下命令检查Java版本,然后根据需要进行相应的安装/升级(java -version)

你可以从ElasticsEarch下载 ,下载你需要的版本的Elasticsearch,解压之后即可使用。

如果是集群形式的,可在 ...\elasticsearch-5.6.0\config\elasticsearch.yml中配置一些你的集群信息:
cluster.name: my-application   # 集群名称
path.data: /path/to/data       # ES数据存储路径
path.logs: /path/to/logs       # ES日志存储路径
node.name: node-1              # 当前节点的名称
network.host: 192.168.0.1      # 配置当前结点绑定的IP地址,可设置为0.0.0.0
http.port: 9200                # 设置对外服务的HTTP端口,默认为9200

2运行 Elasticsearch

elasticsearch 准备好之后,在安装目录中执行以下命令可以启动运行:

Linux

./bin/elasticsearch

Windows

D:\...\elasticsearch-6.4.0\bin\elasticsearch.bat

运行成功之后(启动日志里面会有.. started标志),浏览器访问http://localhost:9200/,你能看到类似以下返回信息(各版本稍微不同):

{"name" : "AGXQ3qy","cluster_name" : "elasticsearch","cluster_uuid" : "mg9t4Yi2TRud1JNwRY0bPA","version" : {"number" : "6.4.0","build_flavor" : "default","build_type" : "zip","build_hash" : "595516e","build_date" : "2018-08-17T23:18:47.308994Z","build_snapshot" : false,"lucene_version" : "7.4.0","minimum_wire_compatibility_version" : "5.6.0","minimum_index_compatibility_version" : "5.0.0"},"tagline" : "You Know, for Search"
}

这说明你的 Elasticsearch 集群已经启动成功并且正常运行,接下来我们可以开始使用了。

可视化 web 界面

由于 Elasticsearch 的交互方式是 Rest 形式的,这种不是很直观方便,我们先安装图视化界面,方便我们操作。可选择的目前主要有 elasticsearch-head 和 kibana。

elasticsearch-head

elasticsearch-head 是一个用于浏览和与 elasticsearch 集群交互的Web前端。elasticsearch-head 是 elasticsearch 集群管理、数据可视化、增删查改、查询语句可视化工具。elasticsearch head 是托管的,可以在 github 下载或 fork。

有两种运行和安装elasticsearch-head的方法:

作为ElasticSearch的插件运行(这是首选方法)

  1. elasticsearch/bin/elasticsearch-plugin -install mobz/elasticsearch-head。
  2. open http://localhost:9200/_plugin/head/。

注意
插件的安装方法,5.0之前为 plugin -install …,而在 5.0 以后为 elasticsearch-plugin -install …

作为独立的webapp运行

  1. git clone git://github.com/mobz/elasticsearch-head.git
  2. 在浏览器中打开 index.html。现代浏览器需要使用 es-head。
  3. 默认情况下,es-head 将尝试连接到http:// localhost:9200 /的集群节点。
    在连接框中输入不同的节点地址,如果需要,单击“连接”。

成功后的界面如下,可以看到集群的状态信息:

正在上传…重新上传取消正在上传…重新上传取消

由于 Head 安装起来比较麻烦( 需要安装 node.js ),网上资料也很多,所以我就不详细说了。

kibana

Kibana 和 elasticsearch 同属于 elastic 公司。 Kibana是一个开源分析和可视化平台,旨在与Elasticsearch协同工作。您使用Kibana搜索,查看和与存储在 Elasticsearch 索引中的数据进行交互。您可以轻松地执行高级数据分析,并在各种图表,表格和地图中可视化您的数据。

正在上传…重新上传取消Kibana 使您可以轻松理解大量数据。其简单的基于浏览器的界面使您能够快速创建和共享动态仪表板,实时显示 Elasticsearch 查询的更改。

设置 Kibana 非常容易。您可以安装 Kibana 并在几分钟内开始探索您的 Elasticsearch 索引 - 无需代码,无需额外的基础架构。

同样可在 kibana 选择需要的对应版本(与 elasticsearch 版本对应),然后下载解压即可使用,具体步骤如下:

  • 下载并解压缩 Kibana。
  • 在编辑器中打开 config / kibana.yml。
  • 设置 elasticsearch.url 为您的Elasticsearch实例,如本地:elasticsearch.url: "http://localhost:9200"
  • 运行 bin/kibana(或bin\kibana.bat在Windows上)。
  • 浏览器输入 http:// localhost:5601。

如果运行成功,但是无法访问,可以关闭防火墙再试试。

5|0基本概念

一切准备就绪,我们正式操作之前,先来了解一些 ES 的核心基本概念,从一开始就理解这些概念将极大地帮助简化学习过程。

Elasticsearch是一个近乎实时(NRT)的搜索平台。这意味着从索引文档到可搜索文档的时间有一点延迟(通常是一秒)。通常有集群,节点,分片,副本等概念。

5|1集群(Cluster)

集群(cluster)是一组具有相同cluster.name的节点集合,他们协同工作,共享数据并提供故障转移和扩展功能,当然一个节点也可以组成一个集群。

集群由唯一名称标识,默认情况下为“elasticsearch”。此名称很重要,因为如果节点设置为按名称加入集群的话,则该节点只能是集群的一部分。

确保不同的环境中使用不同的集群名称,否则最终会导致节点加入错误的集群。

【集群健康状态】

集群状态通过 绿 来标识

  • 绿色 - 一切都很好(集群功能齐全)。
  • 黄色 - 所有数据均可用,但尚未分配一些副本(集群功能齐全)。
  • 红色 - 某些数据由于某种原因不可用(集群部分功能)。

注意:当群集为红色时,它将继续提供来自可用分片的搜索请求,但您可能需要尽快修复它,因为存在未分配的分片。

要检查群集运行状况,我们可以在 Kibana 控制台中运行以下命令GET /_cluster/health,得到如下信息:

{"cluster_name": "elasticsearch","status": "yellow","timed_out": false,"number_of_nodes": 1,"number_of_data_nodes": 1,"active_primary_shards": 28,"active_shards": 28,"relocating_shards": 0,"initializing_shards": 0,"unassigned_shards": 5,"delayed_unassigned_shards": 0,"number_of_pending_tasks": 0,"number_of_in_flight_fetch": 0,"task_max_waiting_in_queue_millis": 0,"active_shards_percent_as_number": 84.84848484848484
}

5|2节点(Node)

节点,一个运行的 ES 实例就是一个节点,节点存储数据并参与集群的索引和搜索功能。

就像集群一样,节点由名称标识,默认情况下,该名称是在启动时分配给节点的随机通用唯一标识符(UUID)。如果不需要默认值,可以定义所需的任何节点名称。此名称对于管理目的非常重要,您可以在其中识别网络中哪些服务器与 Elasticsearch 集群中的哪些节点相对应。

可以将节点配置为按集群名称加入特定集群。默认情况下,每个节点都设置为加入一个名为 cluster 的 elasticsearch 集群,这意味着如果您在网络上启动了许多节点并且假设它们可以相互发现 - 它们将自动形成并加入一个名为 elasticsearch 的集群。

5|3索引(Index)

索引是具有某些类似特征的文档集合。例如,您可以拥有店铺数据的索引,商品的一个索引以及订单数据的一个索引。

索引由名称标识(必须全部小写),此名称用于在对其中的文档执行索引,搜索,更新和删除操作时引用索引。

5|4类型(Type)

类型,曾经是索引的逻辑类别/分区,允许您在同一索引中存储不同类型的文档,例如,一种类型用于用户,另一种类型用于博客帖子。

在 6.0.0 中弃用,以后将不再可能在索引中创建多个类型,并且将在更高版本中删除类型的整个概念

5|5文档(Document)

文档是可以建立索引的基本信息单元。例如,您可以为单个客户提供文档,为单个产品提供一个文档,为单个订单提供一个文档。该文档以JSON(JavaScript Object Notation)表示,JSON是一种普遍存在的互联网数据交换格式。

在索引/类型中,您可以根据需要存储任意数量的文档。请注意,尽管文档实际上驻留在索引中,但实际上必须将文档编入索引/分配给索引中的类型。

5|6分片(Shards)

索引可能存储大量可能超过单个节点的硬件限制的数据。例如,占用1TB磁盘空间的十亿个文档的单个索引可能不适合单个节点的磁盘,或者可能太慢而无法单独从单个节点提供搜索请求。

为了解决这个问题,Elasticsearch 提供了将索引细分为多个称为分片的功能。创建索引时,只需定义所需的分片数即可。每个分片本身都是一个功能齐全且独立的“索引”,可以托管在集群中的任何节点上。

设置分片的目的及原因主要是:

  • 它允许您水平拆分/缩放内容量
  • 它允许您跨分片(可能在多个节点上)分布和并行化操作,从而提高性能/吞吐量

分片的分布方式以及如何将其文档聚合回搜索请求的机制完全由 Elasticsearch 管理,对用户而言是透明的。

在可能随时发生故障的网络/云环境中,分片非常有用,建议使用故障转移机制,以防分片/节点以某种方式脱机或因任何原因消失。为此,Elasticsearch 允许您将索引的分片的一个或多个副本制作成所谓的副本分片或简称副本。

5|7副本(Replicasedit)

副本,是对分片的复制。目的是为了当分片/节点发生故障时提供高可用性,它允许您扩展搜索量/吞吐量,因为可以在所有副本上并行执行搜索。

总而言之,每个索引可以拆分为多个分片。索引也可以复制为零次(表示没有副本)或更多次。复制之后,每个索引将具有主分片(从原始分片复制而来的)和复制分片(主分片的副本)。

可以在创建索引时为每个索引定义分片和副本的数量。创建索引后,您也可以随时动态更改副本数。您可以使用_shrink 和 _splitAPI 更改现有索引的分片数,但这不是一项轻松的任务,所以预先计划正确数量的分片是最佳方法。

默认情况下,Elasticsearch 中的每个索引都分配了5个主分片和1个副本,这意味着如果集群中至少有两个节点,则索引将包含5个主分片和另外5个副本分片(1个完整副本),总计为每个索引10个分片。

5|8小结

我们假设有一个集群由三个节点组成(Node1 , Node2 , Node3)。 它有两个主分片(P0 , P1),每个主分片有两个副本分片(R0 , R1)。相同分片的副本不会放在同一节点,所以我们的集群看起来如下图所示 “有三个节点和一个索引的集群”。

正在上传…重新上传取消

类似于关系型数据库:数据库集群,假如有个用户表,我担心数据量过大,我新建了多个用户表(即 Shard),将用户信息数据切分成多份,然后根据某种规则分到这些用户表中,我又担心某个表会出现异常造成数据丢失,我又将每个表分别备份了一次(即 Replica )。

副本是乘法,越多越浪费,但也越保险。分片是除法,分片越多,单分片数据就越少也越分散。

另外,我们可以画一个对比图来类比传统关系型数据库:

  • 关系型数据库 -> Databases(库) -> Tables(表) -> Rows(行) -> Columns(列)。
  • Elasticsearch -> Indeces(索引) -> Types(类型) -> Documents(文档) -> Fields(属性)。

Elasticsearch集群可以包含多个索引(indices)(数据库),每一个索引可以包含多个类型 (Types)(表),每一个类型包含多个文档(documents)(行),然后每个文档包含多个字段(Fields)(列)。

虽然这么类比,但是毕竟是两个差异化的产品,而且上面也说过在以后的版本中类型 (Types) 可能会被删除,所以一般我们创建索引都是一个种类对应一个索引。生鲜就创建商品的索引,生活用品就创建生活用品的索引,而不会说创建一个商品的索引,里面既包含生鲜的类型,又包含生活用品的类型。

而且你可能已经注意到索引(index)这个词在Elasticsearch中有着不同的含义,所以有必要在此做一下区分:

「索引」含义的区分

  • 索引(名词) 如上文所述,一个索引(index)就像是传统关系数据库中的数据库,它是相关文档存储的地方,index的复数是 indices 或 indexes。
  • 索引(动词) 「索引一个文档」表示把一个文档存储到索引(名词)里,以便它可以被检索或者查询。这很像SQL中的INSERT关键字,差别是,如果文档已经存在,新的文档将覆盖旧的文档。
  • 倒排索引 传统数据库为特定列增加一个索引,例如B-Tree索引来加速检索。Elasticsearch和Lucene使用一种叫做倒排索引(inverted index)的数据结构来达到相同目的。

6|0与Elasticsearch交互

目前与 elasticsearch 交互主要有两种方式:Client API 和 RESTful API。

Client API方式

Elasticsearch 为以下语言提供了官方客户端 --Groovy、JavaScript、.NET、 PHP、 Perl、 Python 和 Ruby--还有很多社区提供的客户端和插件,所有这些都可以在 Elasticsearch Clients 中找到。后面再开一篇来详细说明。

RESTful API with JSON over HTTP

所有其他语言可以使用 RESTful API 通过端口 9200 和 Elasticsearch 进行通信,你可以用你最喜爱的 web 客户端访问 Elasticsearch 。事实上,正如你所看到的,你甚至可以使用 curl 命令来和 Elasticsearch 交互。

一个 Elasticsearch 请求和任何 HTTP 请求一样由若干相同的部件组成:

curl -X<VERB> '<PROTOCOL>://<HOST>:<PORT>/<PATH>?<QUERY_STRING>' -d '<BODY>'

< >标记的部件:

7|0数据格式

在应用程序中对象很少只是一个简单的键和值的列表。通常,它们拥有更复杂的数据结构,可能包括日期、地理信息、其他对象或者数组等。

也许有一天你想把这些对象存储在数据库中。使用关系型数据库的行和列存储,这相当于是把一个表现力丰富的对象挤压到一个非常大的电子表格中:你必须将这个对象扁平化来适应表结构,通常一个字段对应一列,而且又不得不在每次查询时重新构造对象。

Elasticsearch 是面向文档的,意味着它存储整个对象或文档。Elasticsearch 不仅存储文档,而且 每个文档的内容可以被检索。在 Elasticsearch 中,你对文档进行索引、检索、排序和过滤而不是对行列数据。这是一种完全不同的思考数据的方式,也是 Elasticsearch 能支持复杂全文检索的原因。

Elasticsearch 使用 JavaScript Object Notation 或者 JSON 作为文档的序列化格式。JSON 序列化被大多数编程语言所支持,并且已经成为 NoSQL 领域的标准格式。 它简单、简洁、易于阅读。几乎所有的语言都有相应的模块可以将任意的数据结构或对象 转化成 JSON 格式,只是细节各不相同。

{"_index" :   "megacorp","_type" :    "employee","_id" :      "1","_version" : 1,"found" :    true,"_source" :  {"first_name" :  "John","last_name" :   "Smith","age" :         25,"about" :       "I love to go rock climbing","interests":  [ "sports", "music" ]}
}

8|0索引的应用

一切准备就绪之后我们开始来使用起来,体验 ElasticSearch 的世界。首先,我们来查看我们的所有索引信息:

GET _search
{"query": {"match_all": {}}
}

得到如下结果信息:

{"took": 0,"timed_out": false,"_shards": {"total": 1,"successful": 1,"skipped": 0,"failed": 0},"hits": {"total": 1,"max_score": 1,"hits": [{"_index": ".kibana","_type": "config","_id": "5.6.0","_score": 1,"_source": {"buildNum": 15523}}]}
}

可以发现,当前只有一个索引,是.kibana,当然这不是我们自己的,这是kibana的。

8|1创建第一个简单索引

NBA的新的赛季又开始了,我相信大部分人有精彩比赛的时候还是会去关注的,我们创建一个 NBA 球队的索引,开始我们的学习之路,索引名称需是小写。

PUT nba
{"settings":{"number_of_shards": 3,   "number_of_replicas": 1 },"mappings":{"nba":{"properties":{"name_cn":{ "type":"text"},"name_en":{"type":"text"},"gymnasium":{"type":"text"},"topStar":{"type":"text"},"championship":{"type":"integer"},"date":{"type":"date","format":"yyyy-MM-dd HH:mm:ss|| yyy-MM-dd||epoch_millis"}}}}
}

字段说明:

字段名称 字段说明
nba 索引
number_of_shards 分片数
number_of_replicas 副本数
name_cn 球队中文名
name_en 球队英文名
gymnasium 球馆名称
championship 总冠军次数
topStar 当家球星
date 加入NBA年份

如果格式书写正确,我们会得到如下返回信息,表示创建成功

{"acknowledged": true,"shards_acknowledged": true,"index": "nba"
}

8|2新增索引数据

索引创建完成之后,我们往索引中加入球队数据,1,2,3 是我们指定的 ID,如果不写 ES 会默认ID。

其实我们可以不创建上面的索引 mapping 直接推送数据,但是这样 ES 会根据数据信息自动为我们设定字段类型,这会造成索引信息不准确的风险。

PUT /nba/nba/1
{"name_en":"San Antonio Spurs SAS","name_cn":"圣安东尼安马刺","gymnasium":"AT&T中心球馆","championship": 5,"topStar":"蒂姆·邓肯","date":"1995-04-12"
}PUT /nba/nba/2
{"name_en":"Los Angeles Lakers","name_cn":"洛杉矶湖人","gymnasium":"斯台普斯中心球馆","championship": 16,"topStar":"科比·布莱恩特","date":"1947-05-12"
}PUT /nba/nba/3
{"name_en":"Golden State Warriors","name_cn":"金州勇士队","gymnasium":"甲骨文球馆","championship": 6,"topStar":"斯蒂芬·库里","date":"1949-06-13"
}PUT /nba/nba/4
{"name_en":"Miami Heat","name_cn":"迈阿密热火队","gymnasium":"美国航空球场","championship": 3,"topStar":"勒布朗·詹姆斯","date":"1988-06-13"
}PUT /nba/nba/5
{"name_en":"Cleveland Cavaliers","name_cn":"克利夫兰骑士队","gymnasium":"速贷球馆","championship": 1,"topStar":"勒布朗·詹姆斯","date":"1970-06-13"
}

索引数据 PUT 成功,会返回如下信息

{"_index": "nba","_type": "nba","_id": "1","_version": 1,"result": "created","_shards": {"total": 2,"successful": 1,"failed": 0},"created": true
}

8|3查询索引数据

上面新增完数据之后,这时候我们再执行开始的 MATCH_ALL ,就会发现我们自己的索引信息也在查询的结果里面了,只是查询的结果是全部信息,其中包括索引、分片和副本的信息,内容比较多。我们可单独查询自己需要的索引信息。

Elasticsearch 提供丰富且灵活的查询语言叫做 **DSL 查询 (Query DSL) **,它允许你构建更加复杂、强大的搜索。

1.匹配查询 match,match_all

我们尝试一个最简单的搜索全部员工的请求:

# 查询全部球队的信息

GET /nba/nba/_search
{"query": {"match_all": {}}
}

得到的查询结果如下

{"took": 4,"timed_out": false,"_shards": {"total": 3,"successful": 3,"skipped": 0,"failed": 0},"hits": {"total": 3,"max_score": 1,"hits": [{"_index": "nba","_type": "nba","_id": "2","_score": 1,"_source": {"name_en": "Los Angeles Lakers","name_cn": "洛杉矶湖人","gymnasium": "斯台普斯中心球馆","championship": 16,"topStar": "科比·布莱恩特","date": "1947-05-12"}},{"_index": "nba","_type": "nba","_id": "1","_score": 1,"_source": {"name_en": "San Antonio Spurs SAS","name_cn": "圣安东尼安马刺","gymnasium": "AT&T中心球馆","championship": 5,"topStar": "蒂姆·邓肯","date": "1995-04-12"}},{"_index": "nba","_type": "nba","_id": "3","_score": 1,"_source": {"name_en": "Golden State Warriors","name_cn": "金州勇士队","gymnasium": "甲骨文球馆","championship": 6,"topStar": "斯蒂芬·库里","date": "1949-06-13"}···}]}
}

响应的数据结果分为两部分

{
----------------first part--------------------"took": 0,"timed_out": false,"_shards": {"total": 3,"successful": 3,"skipped": 0,"failed": 0},
---------------second part---------------------"hits": {"total": 0,"max_score": null,"hits": []}
}

第一部分为:分片副本信息,第二部分 hits 包装的为查询的数据集。

注意:
响应内容不仅会告诉我们哪些文档被匹配到,而且这些文档内容完整的被包含在其中—我们在给用户展示搜 索结果时需要用到的所有信息都有了。

# 查询英文名称为:"Golden State Warriors" 的球队信息

GET /nba/nba/_search
{"query": {"match": {"name_en": "Golden State Warriors"}}
}

可得到的查询结果为:

{"took": 6,"timed_out": false,"_shards": {"total": 3,"successful": 3,"skipped": 0,"failed": 0},"hits": {"total": 1,"max_score": 1.9646256,"hits": [{"_index": "nba","_type": "nba","_id": "3","_score": 1.9646256,"_source": {"name_en": "Golden State Warriors","name_cn": "金州勇士队","gymnasium": "甲骨文球馆","championship": 6,"topStar": "斯蒂芬·库里","date": "1949-06-13"}}]}
}

2.过滤查询 Filter

我们让搜索变的复杂一些。我们想要找到当家球星是勒布朗·詹姆斯,但是我们只想得到总冠军多余1次的球队。我们的语句将做一些改变用来添加过滤器(filter),它允许我们有效的执行一个结构化搜索:

GET /nba/nba/_search
{"query": {"bool": {"filter": {"range": {"championship": {"gt": 1}}},"must": {"match": {"topStar": "勒布朗·詹姆斯"}}}}
}

我们发现每次查询,查询结果里面都有一个 _score字段,一般Elasticsearch根据相关评分排序,相关评分是根据文档与语句的匹配度来得出, _score值越高说明匹配度越高。

Elasticsearch如何进行全文字段搜索且首先返回相关性性最大的结果。相关性(relevance)概念在Elasticsearch中非常重要,而这也是它与传统关系型数据库中记录只有匹配和不匹配概念最大的不同。

ElasticSearch(一):基础入门相关推荐

  1. Elasticsearch笔记基础入门

    并不能保证通过这四篇文章让你掌握ES,但是!我会用大白话串讲ES的一些概念.和花哨的玩法.起码可以把你对Elasticsearch的陌生度降到最低,等有一天你自己业务需要使用ES时,会因为提前读了ES ...

  2. Elasticsearch 基础入门

    原文地址:Elasticsearch 基础入门 博客地址:http://www.extlight.com 一.什么是 ElasticSearch ElasticSearch是一个基于 Lucene 的 ...

  3. Logstash 基础入门

    原文地址:Logstash 基础入门 博客地址:http://www.extlight.com 一.前言 Logstash 是一个开源的数据收集引擎,它具有备实时数据传输能力.它可以统一过滤来自不同源 ...

  4. SpringBoot2.x(3)---基础入门

    SpringBoot2.x(3)---基础入门 一.概述 Spring Boot设计目的是用来简化新Spring应用的初始搭建以及开发过程.Spring Boot并不是对Spring功能上的增强,而是 ...

  5. Linux命令基础入门

    Linux命令基础入门 这是作者自己为了 Linux期末考试做的知识简介,虽然很简单但是作为Linux入门或者查询手册都是还不错的资料(自认为).里面有很多资料来自于csdn或者其他地方,如果涉及到侵 ...

  6. Java基础入门:IDEA软件安装和软件初始化设置

    IDEA是一个专门针对Java的集成开发工具(IDE),由Java语言编写.所以,需要有JRE运行环境并配置好环境变量. 它可以极大地提升我们的开发效率.可以自动编译,检查错误.在公司中,使用的就是I ...

  7. 2020年关于Linux的知识技术合集(基础入门到高级进阶)

    前言 本文介绍下Linux如何从入门开始到高级进阶的学习路线. 整个体系专注于服务器后台开发,知识点包括C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,Mon ...

  8. Docker基础入门(基本命令)

    Docker基础入门(基本命令) 一.Docker概述 1.Docker为什么会出现? 一款产品: 开发–上线 两套环境!应用环境,应用配置! 开发 - 运维. 问题:我在我的电脑上可以允许!版本更新 ...

  9. Elasticsearch 零基础入坑指南

    文章目录 引言 1.Elasticsearch介绍 1.1 官方释义 1.2 民间叫法 1.3 到底如何定义ES 1.4 新手速记 1.4.1 ES的"擅长"与"不擅长& ...

  10. 2023年最新最全uniCloud入门学习,零基础入门到实战项目 uni-admin打造uniapp网页后端 微信支付宝抖音小程序后端 unicloud数据后台快速打造uniapp小程序项目

    今天开始带着大家一起零基础学习uniCloud,在下面的课程中我们就简称uniCloud为cloud吧.我这里从零基础开始教大家,后面可以带大家简单的做一个实战项目.所以不用担心自己没有基础,跟着石头 ...

最新文章

  1. 很安逸的离线API文档查询工具Dash和Zeal
  2. goland/go语言项目--本地包的导入(将项目添加至GOPATH中)(基于macOS)
  3. Pycharm如何关掉jupyter notebook server
  4. Android本地视频播放器开发--视频解码
  5. CF938E Max History
  6. 规格示例_最佳引导示例
  7. 解决nginx下connect() to 127.0.0.1:3000 failed
  8. 【算法导论33】跳跃表(Skip list)原理与java实现
  9. 快速乘 O(lgn) and O(1)
  10. ui曲线谁是横坐标_一篇文章讲明白,曲线在摄影修图中的运用
  11. DOTA模式命令详解 及 DotA英雄英文名字和简称
  12. BZOJ 4198 [Noi2015 D2T1] 荷马史诗
  13. 用Desmos玩极坐标
  14. 服务器引擎制作,2.5D-GIS地图引擎设计
  15. 获取token(/oauth/token)
  16. 我的同学聚会--性格决定命运[转载]
  17. 自动分账系统怎么开通?
  18. Word 批注的使用
  19. HTML入门手敲学习笔记
  20. SL-Sensor:基于结构光的高精度开源三维重建系统(arxiv2022)

热门文章

  1. 电源硬件设计----全桥变换器(Full-Bridge Converter)基础
  2. 自己拍摄的视频剪辑时如何消音?
  3. Linux 下第一次使用MySQL遇到几种问题。
  4. [物理学与PDEs]第5章第4节 本构方程 - 应力与变形之间的关系
  5. ug安装许可文件指定服务器错误,NX许可证错误,NX要求正确配置环境变量
  6. 闲鱼采集及监控下单软件开发
  7. c语言 《显示器》,C语言基础:你知道吗,对于C语言来说我们的显示器只是一个文件...
  8. 腾讯乘车码公众号裂变涨粉实操案例分析!
  9. 2020计算机考研院校推免,2020考研:热门院校推免比例超90%?他们说尝试了就不后悔!...
  10. 搜狗PC权重 麦谈帮API数据接口