ES详解 - 索引:索引管理详解
ES详解 - 索引:索引管理详解
了解基本使用后,我们从索引操作的角度看看如何对索引进行管理。@pdai
索引管理的引入
我们在前文中增加文档时,如下的语句会动态创建一个customer的index:
PUT /customer/_doc/1
{
"name": "John Doe"
}
而这个index实际上已经自动创建了它里面的字段(name)的类型。我们不妨看下它自动创建的mapping:
{
"mappings": {
"_doc": {
"properties": {
"name": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword",
"ignore_above": 256
}
}
}
}
}
}
}
那么如果我们需要对这个建立索引的过程做更多的控制:比如想要确保这个索引有数量适中的主分片,并且在我们索引任何数据之前,分析器和映射已经被建立好。那么就会引入两点:第一个禁止自动创建索引,第二个是手动创建索引。
- 禁止自动创建索引
可以通过在 config/elasticsearch.yml 的每个节点下添加下面的配置:
action.auto_create_index: false
手动创建索引就是接下来文章的内容。
索引的格式
在请求体里面传入设置或类型映射,如下所示:
PUT /my_index
{
"settings": { ... any settings ... },
"mappings": {
"properties": { ... any properties ... }
}
}
- settings: 用来设置分片,副本等配置信息
- mappings: 字段映射,类型等 * properties: 由于type在后续版本中会被Deprecated, 所以无需被type嵌套
索引管理操作
我们通过kibana的devtool来学习索引的管理操作。
创建索引
我们创建一个user 索引test-index-users
,其中包含三个属性:name,age, remarks; 存储在一个分片一个副本上。
PUT /test-index-users
{
"settings": {
"number_of_shards": 1,
"number_of_replicas": 1
},
"mappings": {
"properties": {
"name": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword",
"ignore_above": 256
}
}
},
"age": {
"type": "long"
},
"remarks": {
"type": "text"
}
}
}
}
执行结果
data:image/s3,"s3://crabby-images/d0d60/d0d60d95e23d0854be16be5d188b891008296d24" alt="es-index-manage-1.png"
- 插入测试数据
data:image/s3,"s3://crabby-images/fabfb/fabfb4396ba022a9cbaea9e5af1f091d72e60926" alt="es-index-manage-2.png"
查看数据
data:image/s3,"s3://crabby-images/a1c5a/a1c5afe9413b4ee6e00eaad2b5262e93a73a82aa" alt="es-index-manage-3.png"
- 我们再测试下不匹配的数据类型(age):
POST /test-index-users/_doc
{
"name": "test user",
"age": "error_age",
"remarks": "hello eeee"
}
你可以看到无法类型不匹配的错误:
data:image/s3,"s3://crabby-images/a45db/a45db8e23b56889c9c53baee93b20fc5c526a066" alt="es-index-manage-4.png"
修改索引
查看刚才的索引,curl 'localhost:9200/_cat/indices?v' | grep users
yellow open test-index-users LSaIB57XSC6uVtGQHoPYxQ 1 1 1 0 4.4kb 4.4kb
我们注意到刚创建的索引的状态是yellow的,因为我测试的环境是单点环境,无法创建副本,但是在上述number_of_replicas
配置中设置了副本数是1; 所以在这个时候我们需要修改索引的配置。
修改副本数量为0
PUT /test-index-users/_settings
{
"settings": {
"number_of_replicas": 0
}
}
data:image/s3,"s3://crabby-images/65e9d/65e9d7da883e3c3d370f576bcabdedefbf2cb95a" alt="es-index-manage-5.png"
再次查看状态:
green open test-index-users LSaIB57XSC6uVtGQHoPYxQ 1 1 1 0 4.4kb 4.4kb
打开/关闭索引
- 关闭索引
一旦索引被关闭,那么这个索引只能显示元数据信息,不能够进行读写操作。
data:image/s3,"s3://crabby-images/83923/83923c5d7ef6108b88020cafedfde3fea4102f3d" alt="es-index-manage-7.png"
当关闭以后,再插入数据时:
data:image/s3,"s3://crabby-images/3db1e/3db1e9c783e59743a941feee30cba588f1bdf5fa" alt="es-index-manage-8.png"
- 打开索引
data:image/s3,"s3://crabby-images/a17ab/a17abd112e83ef1ed170b825af7864d484d6dacf" alt="es-index-manage-9.png"
打开后又可以重新写数据了
data:image/s3,"s3://crabby-images/d0630/d063088e3f0283e0e5e93efd774fedeb111d4675" alt="es-index-manage-10.png"
删除索引
最后我们将创建的test-index-users删除。
DELETE /test-index-users
data:image/s3,"s3://crabby-images/edb42/edb428dff697edef4894d90bc3c4f62ab563e3ab" alt="es-index-manage-11.png"
查看索引
由于test-index-users被删除,所以我们看下之前bank的索引的信息
- mapping
GET /bank/_mapping
data:image/s3,"s3://crabby-images/306ca/306ca657e8e69ef9ea60f6f56a1b5a06672cdd3c" alt="es-index-manage-12.png"
- settings
GET /bank/_settings
data:image/s3,"s3://crabby-images/73df5/73df57535b94b7be15c47f34179a1f5c069fcbb4" alt="es-index-manage-13.png"
Kibana管理索引
在Kibana如下路径,我们可以查看和管理索引
data:image/s3,"s3://crabby-images/bf3a2/bf3a22d13629e53ac8a8a4cdb98d3c21f46b11de" alt="es-index-manage-6.png"
参考文章
https://www.elastic.co/guide/cn/elasticsearch/guide/current/_creating_an_index.html
https://www.elastic.co/guide/en/elasticsearch/reference/current/mapping.html
https://www.elastic.co/guide/en/elasticsearch/reference/current/removal-of-types.html
https://www.cnblogs.com/quanxiaoha/p/11515057.html