集群状态查看
-
查看集群健康状态
GET /_cat/health?v
-
查看节点状态
GET /_cat/nodes?v
-
查看所有索引信息
GET /_cat/indices?v
索引操作
-
创建索引并查看
PUT /customer GET /_cat/indices?v
-
删除索引并查看
DELETE /customer GET /_cat/indices?v
类型操作
-
查看文档的类型
GET /bank/account/_mapping
文档操作
-
在索引中添加文档
PUT /customer/doc/1
{ "name": "John Doe" }
-
查看索引中的文档
GET /customer/doc/1
-
修改索引中的文档
POST /customer/doc/1/_update
{ "doc": { "name": "Jane Doe" } }
-
删除索引中的文档
DELETE /customer/doc/1
-
对索引中的文档执行批量操作
POST /customer/doc/_bulk
{"index":{"_id":"1"}} {"name": "John Doe" } {"index":{"_id":"2"}} {"name": "Jane Doe" }
数据搜索
-
最简单的搜索,使用
match_all来表示,例如搜索全部GET /bank/_search { "query": { "match_all": {} } }
-
分页搜索,
from表示偏移量,从0开始,size表示每页显示的数量GET /bank/_search { "query": { "match_all": {} }, "from": 0, "size": 10 }
-
搜索排序,使用
sort表示,例如按balance字段降序排列GET /bank/_search { "query": { "match_all": {} }, "sort": { "balance": { "order": "desc" } } }
-
搜索并返回指定字段内容,使用
_source表示,例如只返回account_number和balance两个字段内容GET /bank/_search { "query": { "match_all": {} }, "_source": ["account_number", "balance"] }
条件搜索
-
条件搜索,使用
match表示匹配条件,例如搜索出account_number为20的文档GET /bank/_search { "query": { "match": { "account_number": 20 } } }
-
文本类型字段的条件搜索,例如搜索
address字段中包含mill的文档,对比上一条搜索可以发现,对于数值类型match操作使用的是精确匹配,对于文本类型使用的是模糊匹配GET /bank/_search { "query": { "match": { "address": "mill" } }, "_source": [ "address", "account_number" ] }
-
短语匹配搜索,使用
match_phrase表示,例如搜索address字段中同时包含mill和lane的文档GET /bank/_search { "query": { "match_phrase": { "address": "mill lane" } } }
组合搜索
-
组合搜索,使用
bool来进行组合,must表示同时满足,例如搜索address字段中同时包含mill和lane的文档GET /bank/_search { "query": { "bool": { "must": [ { "match": { "address": "mill" } }, { "match": { "address": "lane" } } ] } } }
-
组合搜索,
should表示满足其中任意一个,搜索address字段中包含mill或者lane的文档GET /bank/_search { "query": { "bool": { "should": [ { "match": { "address": "mill" } }, { "match": { "address": "lane" } } ] } } }
-
组合搜索,
must_not表示同时不满足,例如搜索address字段中不包含mill且不包含lane的文档GET /bank/_search { "query": { "bool": { "must_not": [ { "match": { "address": "mill" } }, { "match": { "address": "lane" } } ] } } }
-
组合搜索,组合
must和must_not,例如搜索age字段等于40且state字段不包含ID的文档GET /bank/_search { "query": { "bool": { "must": [ { "match": { "age": "40" } } ], "must_not": [ { "match": { "state": "ID" } } ] } } }
过滤搜索
-
搜索过滤,使用
filter来表示,例如过滤出balance字段在20000~30000的文档GET /bank/_search { "query": { "bool": { "must": { "match_all": {} }, "filter": { "range": { "balance": { "gte": 20000, "lte": 30000 } } } } } }
搜索聚合
-
对搜索结果进行聚合,使用
aggs来表示,类似于MySql中的group by,例如对state字段进行聚合,统计出相同state的文档数量GET /bank/_search { "size": 0, "aggs": { "group_by_state": { "terms": { "field": "state.keyword" } } } }
-
嵌套聚合,例如对
state字段进行聚合,统计出相同state的文档数量,再统计出balance的平均值GET /bank/_search { "size": 0, "aggs": { "group_by_state": { "terms": { "field": "state.keyword" }, "aggs": { "average_balance": { "avg": { "field": "balance" } } } } } }
-
对聚合搜索的结果进行排序,例如按
balance的平均值降序排列
相关概念
-
Near Realtime(近实时):Elasticsearch是一个近乎实时的搜索平台,这意味着从索引文档到可搜索文档之间只有一个轻微的延迟(通常是一秒钟)。
-
Cluster(集群):群集是一个或多个节点的集合,它们一起保存整个数据,并提供跨所有节点的联合索引和搜索功能。每个群集都有自己的唯一群集名称,节点通过名称加入群集。
-
Node(节点):节点是指属于集群的单个Elasticsearch实例,存储数据并参与集群的索引和搜索功能。可以将节点配置为按集群名称加入特定集群,默认情况下,每个节点都设置为加入一个名为
elasticsearch的群集。 -
Index(索引):索引是一些具有相似特征的文档集合,类似于MySql中数据库的概念。
-
Type(类型):类型是索引的逻辑类别分区,通常,为具有一组公共字段的文档类型,类似MySql中表的概念。
注意:在Elasticsearch 6.0.0及更高的版本中,一个索引只能包含一个类型。 -
Document(文档):文档是可被索引的基本信息单位,以JSON形式表示,类似于MySql中行记录的概念。
-
Shards(分片):当索引存储大量数据时,可能会超出单个节点的硬件限制,为了解决这个问题,Elasticsearch提供了将索引细分为分片的概念。分片机制赋予了索引水平扩容的能力、并允许跨分片分发和并行化操作,从而提高性能和吞吐量。
-
Replicas(副本):在可能出现故障的网络环境中,需要有一个故障切换机制,Elasticsearch提供了将索引的分片复制为一个或多个副本的功能,副本在某些节点失效的情况下提供高可用性。