AWS elasticsearch 禁用所有索引的复制

问题描述

我使用的是单节点 AWS ES 集群。目前,它的健康状态显示为黄色,这很明显,因为没有其他节点可供 Amazon ES 分配副本。我想将所有当前和即将到来的索引的复制设置为 0。我在这种模式中创建了索引:

app-one-2021.02.10
app-two-2021.01.11
so on...

这些索引当前将 number_of_replicas 设置为 1。为了禁用所有索引的复制,我在索引模式中抛出一个 PUT 请求:

PUT /app-one-*/_settings
{
 "index" : {
  "number_of_replicas":0
 }
}

因为我在这里使用了通配符,所以它应该在所有匹配的索引中将 number_of_replicas 设置为 0,这很成功。

但如果将来创建任何新索引,我们假设 app-one-2021.03.10。然后 number_of_replicas 在此索引中再次设置为 1。

每次我必须运行 PUT 请求以将 number_of_replicas 设置为 0 时,这很乏味。为什么即使我在 PUT 请求中使用通配符 (*),新索引也不会自动number_of_replicas 变为 0

有什么办法可以将replication(number_of_replicas0)完全设置为0,不管是新索引还是旧索引。我怎样才能做到这一点?

解决方法

是的,方法是定义索引模板。

在 Elasticsearch v7.8 之前,您只能使用 _template API (see docs)。例如,在您的情况下,您可以创建一个匹配所有 app-* 索引的模板:

PUT _template/app_settings
{
  "index_patterns": ["app-*"],"settings": {
    "number_of_replicas": 0
  }
}

自 Elasticsearch v7.8 起,旧 API 仍受支持但已弃用,您可以改用 _index_template API (see docs)。

PUT _index_template/app_settings
{
  "index_patterns": ["app-*"],"template": {
    "settings": {
      "number_of_replicas": 0
    }
  }
}

更新:为 _template_index_template API 添加代码片段。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...