【Elasticsearch】-操作index

参考文档

https://www.elastic.co/guide/en/elasticsearch/reference/7.11/index-modules.html#_settings_in_other_index_modules

一个 Elasticsearch 索引只是一个或多个物理分片的逻辑组,其中每个分片实际上是一个独立索引。通过将索引中的文档分布在多个分片上,并将这些分片分布在多个节点上。

一、索引设置

1.1索引静态设置

索引创建时或索引关闭时才能修改的设置;

1.2索引动态设置

在索引运行时可使用更新索引 API 修改的设置;

以下是索引经常使用的设置参数及说明,具体参数及设置请查看官方文档索引模块。

分类

参数

说明

索引静态设置

number_of_shards

索引的主分片数,默认为1只能索引创建时设置,设置后不能修改。

number_of_routing_shards

用于拆分 (split)索引路由分片数

index.shard.check_on_startup

打开之前是否应检查分片是否损坏。当检测到损坏时,它将阻止分片被打开。默认值为false

codec

默认使用LZ4压缩存储数据,可使用best_compression更高的压缩比,但降低存储字段性能。

索引动态设置

number_of_replicas

每个主分片的副本(备份数),默认值为1

index.refresh_interval

多久执行一次刷新操作,这使得对索引的最近更改对搜索可见。

auto_expand_replicas

根据集群中数据节点的数量自动扩展副本的数量。设置为以破折号分隔的下限和上限(例如 0-5)或使用 all 作为上限(例如 0-all)。默认为 false(即禁用)。

二、创建索引

索引名称必须符合以下规则,RestApi都在kibana中执行。

  • 只能是小写字符
  • 不能包含字符:\、/、*、?、"、<、>、|、 (空格)、,、#
  • 7.0 之前索引可以包含冒号(:),但在 7.0 之后不推荐。
  • 不能以 -、_、+ 开头
  • 不能是 . 或 ..
  • 长度不能超过 255 字节(注意是字节,所以多字节字符会更快达到 255 的限制)
  • 名字以 . 开头不推荐,除非由插件管理的隐藏索引和内部索引
# 创建名称为test-index-000001的索引,主分片数为1,副本分片为1
PUT /test-index-000001
{
  "settings": {
    "number_of_shards": 1,
    "number_of_replicas": 1
  }
}
# 响应示例
# cknowledged 表明在集群中索引是否成功创建,
# hards_acknowledged 表明在超时之前,是否为每个分片启动了必需的分片副本数量。
{
  "acknowledged": true,
  "shards_acknowledged": true,
  "index": "test"
}


三、判断

判断索引是否存在
HEAD /test-index-000001
#响应
200 - OK


四、查询索引

#查询全部索引
GET /_cat/indices
#查询单个索引
GET /test-index-000001


【Elasticsearch】-操作index

【Elasticsearch】-操作index


五、删除索引

#删除单个索引
DELETE test-index-000001  
#删除多个索引 多个索引名称以“,”分隔
DELETE test-index-000001,test-index-000002,test-index-000003


六、关闭、开启索引

#关闭索引
POST /test-index-000001/_close
{
  "acknowledged" : true,
  "shards_acknowledged" : true,
  "indices" : {
    "test-index-000001" : {
      "closed" : true
    }
  }
}
#开启索引
POST /test-index-000001/_open
{
  "acknowledged" : true,
  "shards_acknowledged" : true
}


上一篇:阿里云安装elastic


下一篇:【Elasticsearch】-批量操作