elasticsearch-head安装和介绍已在上一篇讲了。html
在浏览器访问http://localhost:9100,可看到以下界面,表示启动成功:node
仔细观察,咱们会发现客户端默认链接的是咱们elasticsearch的默认路径。而此时elasticsearch服务未启动,因此集群健康值是未链接数据库
集群健康值的几种状态以下:json
绿色,最健康的状态,表明全部的分片包括备份均可用浏览器
黄色,基本的分片可用,可是备份不可用(也多是没有备份),下文有提到app
红色,部分的分片可用,代表分片有一部分损坏。此时执行查询部分数据仍然能够查到,遇到这种状况,仍是赶快解决比较好elasticsearch
灰色,未链接到elasticsearch服务分布式
此时,咱们启动elasticsearch服务,从新刷新浏览器,发现集群健康值变成了黄色,以下:ide
集群名字:xwj。在配置文件(elasticsearch.yml)中设置 cluster.name:工具
经过上图能够看到咱们的节点名称为elasticsearch,而且该节点下有两个索引test_index一、test_index2
在test_index2下,选择 信息-->索引信息,能够查看该索引的全部信息,包括mappings、setting等等
在test_index2下,选择 动做-->关闭/开启,能够关闭/开启该索引,关闭后的索引如图:
在该界面也能够模糊查询索引、设置刷新频率等操做。以下图:
几个查询
集群健康:localhost:9200/_cat/health?v
集群的节点列表:localhost:9200/_cat/nodes?v
查看所有索引:localhost:9200/_cat/indices?v
在这里,能够查看到全部的索引,而且还能够建立一个新的索引,以下图:
建立结构化索引
上图建立的索引,点开索引信息,mapping是空的,表示该索引的字段并无指定,咱们能够在建立索引的时候直接指定其字段名来建立。经过发送http请求来实现。
使用Head的符合查询 或者postman工具进行创
请求路径:localhost:9200/book --》ES服务的ip:端口/要建立的索引名,请求方法:PUT
请求体:
{
"settings":{
"number_of_shards":5, //分片数
"number_of_replicas":1 //备份数
},
//映射文件
"mappings":{
//类型名
"novel":{
//文档的全部字段以及类型
"properties":{
"name":{
"type":"text"
},
"author":{
"type":"keyword"
},
"word_count":{
"type":"integer"
},
"publish_date":{
"type":"date",
"format":"yyyy-MM-dd HH:mm:ss || yyyy-MM-dd" //日期格式化容许的类型
}
}
}
}
}
关于结构化索引和非结构化索引的区别:
结构化索引,相似MySQL,咱们会对索引结构作预约义,包括字段名,字段类型等;那么,非结构化索引,就相似Mongo,索引结构未知,根据具体的数据来update索引的mapping。
那么如何选择两种索引呢,仍是跟具体的使用场景有关,结构化相比非结构化,更易优化,性能好些,非结构化相较灵活,只是频繁update索引mapping会有必定的性能损耗。
重点:须要特别特别注意的是:若是你的索引后期要修改,那么你只能重建一个你要修改为的索引,而后将数据复制到新的索引中,代码以下
POST localhost:9200/_reindex
{
"source": {
"index": "people"
},
"dest": {
"index": "book"
}
}
参考:Elasticsearch index fields 重命名
这里可看到索引、类型、字段、数据信息,以下图所示:
集群(Cluster):
ES是一个分布式的搜索引擎,通常由多台物理机组成。这些物理机,经过配置一个相同的cluster name,互相发现,把本身组织成一个集群。
节点(Node):
同一个集群中的一个Elasticsearch实例就是一个Node。一个机器能够有多个实例,因此并不能说一台机器就是一个node。不过大多数状况下每一个node运行在一个独立的环境或虚拟机上。
Node类型:
1)data node: 存储index数据。Data nodes hold data and perform data related operations such as CRUD, search, and aggregations.
2)client node: 不存储index,处理转发客户端请求到Data Node。
3)master node: 不存储index,集群管理,如管理路由信息(routing infomation),判断node是否available,当有node出现或消失时重定位分片(shards),当有node failure时协调恢复。
(全部的master node会选举出一个master leader node)
详情参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/current/modules-node.html
分片(shard):
分片,ES是分布式搜索引擎,每一个索引有一个或多个分片,索引的数据被分配到各个分片上,至关于一桶水用了N个杯子装,分片有助于横向扩展,N个分片会被尽量平均地(rebalance)分配在不一样的节点上(例如你有2个节点,4个主分片(不考虑备份),那么每一个节点会分到2个分片,后来你增长了2个节点,那么你这4个节点上都会有1个分片,这个过程叫relocation,ES感知后自动完成),分片是独立的,对于一个Search Request的行为,每一个分片都会执行这个Request.
主分片(Primary shard):
索引(下文介绍)的一个物理子集。同一个索引在物理上能够切多个分片,分布到不一样的节点上。分片的实现是Lucene 中的索引。
注意:ES中一个索引的分片个数是创建索引时就要指定的,创建后不可再改变。因此开始建一个索引时,就要预计数据规模,将分片的个数分配在一个合理的范围。
副本分片(Replica shard):
能够理解为备份分片。每一个主分片能够有一个或者多个副本,个数是用户本身配置的。ES会尽可能将同一索引的不一样分片分布到不一样的节点上,提升容错性。对一个索引,只要不是全部shards所在的机器都挂了,就还能用。主分片和备分片不会出如今同一个节点上(防止单点故障),默认状况一个索引建立5个分片一个副本(一个副本是指复制一次,有几个分片复制几个)(即5 primary+5 replica=10个分片)。若是你只有一个节点,那么5个replica都没法分配(unassigned),此时cluster status会变成Yellow。
eg:新建两个索引testshards和testa,选择的 分片数和副本数分别为(5,2)和(1,1),建索引时分片数指 主分片数。
replica的做用主要包括:
1.容灾:primary分片丢失,replica分片就会被顶上去成为新的主分片,同时根据这个新的主分片建立新的replica,集群数据安然无恙
2.提升查询性能:replica和primary分片的数据是相同的,因此对于一个query既能够查主分片也能够查备分片,在合适的范围内多个replica性能会更优(但要考虑资源占用也会提高[cpu/disk/heap]),另外index request只能发生在主分片上,replica不能执行index request。
对于一个索引,除非重建索引不然不能调整分片的数目(主分片数, number_of_shards),但能够随时调整replica数(number_of_replicas)。
索引(Index):
逻辑概念,一个可检索的文档对象(documents)的集合。相似与DB中的database概念。同一个集群中可创建多个索引。好比,生产环境常见的一种方法,对每月产生的数据建索引,以保证单个索引的量级可控。
类型(Type):
索引的下一级概念,至关于数据库中的table。同一个索引里能够包含多个 Type。 数据浏览tab中,选中某个索引或者类型,均可以看它对应的类型或索引。
文档(Document):
即搜索引擎中的文档概念,也是ES中一个能够被检索的基本单位,至关于数据库中的row,一条记录。
字段(Field):
至关于数据库中的column。ES中,每一个文档,实际上是以json形式存储的。而一个文档能够被视为多个字段的集合。好比一篇文章,可能包括了主题、摘要、正文、做者、时间等信息,每一个信息都是一个字段,最后被整合成一个json串,落地到磁盘。
映射(Mapping):
至关于数据库中的schema,用来约束字段的类型,不过 Elasticsearch 的 mapping 能够不显示地指定、自动根据文档数据建立。
ES比传统关系型数据库,对一些概念上的理解:
Relational DB -> Databases -> Tables -> Rows -> Columns Elasticsearch -> Indices -> Types -> Documents -> Fields
参考:
在这个页签,能够作数据项简单的查询(只能作查询)。
选择一个索引,而后再选择不一样的查询条件,勾选“显示查询语句”,最后点击搜索,能够看到具体的查询json和查询结果
至于不一样组合的查询条件表示的意思 -> ElasticSearch查询
在这个页签,可使用json进行复杂的查询,也可发送put请求新增及跟新索引,使用delete请求删除索引等等。如图所示:
该页签的简单使用 -> ElasticSearch索引文档的增删改查
固然也能够采用postman去执行这些操做 -> ElasticSearch数据导入By Postman