微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AWS elasticsearch 禁用所有索引的复制

如何解决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 添加代码片段。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?