Elasticsearch 从入门到学会之六(索引API-特殊管理)

elastic

在上一篇中,我们总结了与索引属性相关的 API。本篇中,我们将介绍一些特殊的管理 API,包括索引模板 API,对索引的监控和状态管理 API,还有特别的悬挂索引。

以下全部 API 可以参阅索引 API

索引模板

索引模板自动为新索引应用设置、映射以及别名。换句话讲,就是设置了模板的话,在创建新索引时,如果新索引符合模板的规则,那么新索引会自动应用模板中定义的索引相关的设置,不用自己再为每个新索引指定。

  • 创建或更新模板

    PUT /_index_template/<index-template>

    使用 PUT 方法,API 中需要在最后指定模板名字。而请求体中可以指定的参数比较多,示例如下:

    PUT /_index_template/template_1
    {
      "index_patterns" : ["te*"],
      "priority" : 1,
      "template": {
        "settings" : {
          "number_of_shards" : 2
        }
      }
    }
    
    • index_patterns 必填,且最重要的。代表匹配此模板的新索引。只要按此规则匹配上了,就会应用这个模板。
    • priority 可选,代表模板的优先级,默认为最低级 0。要注意的是,如果多个模板都匹配上新索引了,那么会使用优先级最高的模板。而且不能创建内容一样,优先级也一样的模板。
    • template 可选,代表所有应用于索引的属性配置。比如包含 aliasesmappingssettings
    • composed_of 可选,可以选择组成索引模板的组件模板名字,以组件模板来组合索引模板。
  • 获取索引模板

    GET /_index_template/<index-template>

    使用 GET 方法。API 中带上模板名字,名字中还可以使用星号作为通配符。

  • 删除索引模板

    DELETE /_index_template/<index-template>

    使用 DELETE 方法。API 中带上模板名字,还可以用逗号分隔多个名字。但需要注意,如果用多个名字的话,就不能用星号通配符。

  • 创建或更新组件模板

    组件模板是比索引模板还小的模板,可用来组成索引模板。

    PUT /_component_template/<component-template>

    使用 PUT 方法。API 中带上组件模板名字。示例如下:

    PUT _component_template/template_1
    {
      "template": {
        "settings": {
          "number_of_shards": 1
        },
        "mappings": {
          "_source": {
            "enabled": false
          },
          "properties": {
            "host_name": {
              "type": "keyword"
            },
            "created_at": {
              "type": "date",
              "format": "EEE MMM dd HH:mm:ss Z yyyy"
            }
          }
        }
      }
    }
    
    • template 必需的。代表索引相关的属性配置,包含 aliasesmappingssettings
  • 获取组件模板

    GET /_component_template/<component-template>

    使用 GET 方法。API 中带上组件模板名字,可以使用星号通配符。如果完全不写组件模板名字,就会查询出所有组件模板。

  • 删除组件模板

    DELETE /_component_template/<component-template>

    使用 DELETE 方法。API 中带上组件模板名字,可以用逗号分隔多个名字或者使用通配符。

  • 模拟索引

    实验性API 用来模拟如果创建一个新索引,应用索引模板后的索引配置会是哪些。

    POST /_index_template/_simulate_index/<index>

    使用 POST 方法。API 中还要带上模拟的索引的名字。要注意,虽然是 POST 方法,但是并不需要传递请求体数据。

  • 模拟索引模板 POST /_index_template/_simulate/<index-template>

    使用 POST 方法。API 中带上索引模板的名字。请求体和索引模板一样。

以上和模板相关的 API,我们可以看到,Elasticsearch 提供了索引模板增删查改相关的接口,还为索引模板提供了更细粒度的组件模板,让索引模板组合更灵活。更进一步,还提供了模拟接口,可以模拟验证创建索引和模板时生成的配置的具体情况。

监测

监控相关的 API,主要用来统计当前索引的一些信息。

  • 索引统计

    GET /<target>/_stats/<index-metric>
    GET /<target>/_stats
    GET /_stats
    

    使用 GET 方法。三种请求形式中,前后两个参数都是可选的。

    • <target> 可选,代表索引的名字,可以不填此参数,或者用 *_all,代表查所有索引的数据。
    • <index-metric>可选,要查询的指标值,包括 _allcompletiondocsfielddataflushgetindexingmergequery_cachequery_cacherefreshrequest_cachesearchsegmentsstoresuggest``translogwarmer

    具体想用哪些参数相关的统计信息,在用的时候再看文档查看即可,参阅索引统计

  • 索引段

    GET /<target>/_segments
    GET /_segments
    

    使用 GET 方法。两种请求形式其实也只是一种。API 中的参数代表索引名称,如果忽略就代表所有索引。

    此 API 用于统计索引基于 Lucene 的索引段。

  • 索引恢复

    GET /<target>/_recovery
    GET /_recovery
    

    使用 GET 方法。两种请求形式是一种。API 中的参数代表索引名称,忽略则代表所有索引。

    此 API 用于获取正在进行和已完成的分片恢复的信息。

  • 索引分片存储

    GET /<target>/_shard_stores
    GET /_shard_stores
    

    使用 GET 方法。两种请求形式其实也是一种,同上面一样,API 中的参数代表索引名称,忽略则代表所有索引。

    此 API 获取索引中分片的存储信息。

    以上关于监测的 API,可以看到,主要是用于对索引的相关信息进行统计或查询,以了解当前索引的一个运行、占用相关的信息,主要用于常规的监控、检查等用途。

状态管理

  • 清除缓存

    POST /<target>/_cache/clear
    POST /_cache/clear
    

    使用 POST 方法。两种请求形式一致。API 中参数代表索引名称,忽略则代表所有索引。

    此 API 用于清除索引的缓存。

  • 刷新

    POST <target>/_refresh
    GET <target>/_refresh
    POST /_refresh
    GET /_refresh
    

    使用 GET 或者 POST 方法。API 中参数代表索引名称,忽略则代表所有索引。

    此 API 进行刷新后,可以使最近对一个或多个索引执行的操作可用于搜索。意思就是说如果你对索引做过一些操作,导致了它的数据变更或者属性变更,后台是需要一定时间才会将变更生效。在生效前,如果你执行搜索,这些变更是不会在搜索中被发现的,然后你想让这些变更立即生效,那就可以执行此 API 让 Elasticsearch 将这些变更立即生效。

    但这里,有一个矛盾的地方是,刷新是一个资源密集型操作,Elasticsearch 本身会按配置进行定时刷新,且刷新操作还是异步的。所以官方更多是建议在操作后添加刷新等待的参数 refresh=wait_for

  • 冲刷

    POST /<target>/_flush
    GET /<target>/_flush
    POST /_flush
    GET /_flush
    

    使用 GETPOST 方法。API 中参数代表索引名称,忽略则代表所有索引。

    此 API 进行冲刷后,确保索引在事务日志中的数据永久存储在 Lucene 中。从英文来看,刷新的refresh和 冲刷的 flush,中文都有刷新的含义。二者在 API 中的语义区别是:刷新是把操作变更,更新到 Elasticsearch 中,这个时候可能还存储在事务日志中,但可被搜索获取到;而冲刷操作,则是把数据真实的永久存储到底层的 Lucene 中。

  • 同步冲刷

    7.6版本已废弃了,8.0将移除,看一眼就行了。

    POST /<index>/_flush/synced
    GET /<index>/_flush/synced
    POST /_flush/synced
    GET /_flush/synced
    
  • 强制合并

    POST /<target>/_forcemerge
    POST /_forcemerge
    

    使用 POST 方法。API 中参数代表索引名字,忽略或者传递*_all 代表所有索引。

    此 API 可以将索引的分片合并在一起,减少片段数,释放被删除文档使用的空间。实际上,官方提到强制合并对于管理数据流的旧备份索引和基于时间的索引非常有用。

以上 API 主要用于对索引的状态管理,人为的将索引的数据所在的状态、存储位置进行更新。

悬空索引

  • 列出悬空索引

    GET /_dangling

    使用 GET 方法。将所有悬空的索引列出。悬空索引是指,当前遇到的集群状态中缺少的索引数据,这些索引就会被认为悬空。要恢复的他们的话,可以使用下面的导入,如果不需要他们了,可以使用下面的删除。

  • 导入悬空索引

    POST /_dangling/<index-uuid>?accept_data_loss=true

    使用 POST 方法。API 中参数是必填的,表示要导入的索引的 UUID。

  • 删除悬空索引

    DELETE /_dangling/<index-uuid>?accept_data_loss=true

    使用 DELETE 方法。API 中的参数必填的,表示要删除的索引的 UUID。

本篇所介绍的 API 主要用于对索引本身状态、存储的相关管理,一般使用 Elasticsearch 的情况下,我们可能较少使用这些 API。当开始进阶时,可能才会慢慢使用这些 API 来辅助我们对 Elasticsearch 的高级使用。

通过连续三篇的介绍,我们初步了解了关于索引的一些 API,包括对索引的管理(增删查改),对索引相关属性的介绍(映射、设置、别名),以及本篇对索引的特殊管理(状态、存储)。

接下来我们将对最核心的搜索相关 API 进行介绍,毕竟 Elasticsearch 离不开的,就是一个 搜索/search

参阅 Elasticsearch中文文档

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容