如何解决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_replicas
到0
)完全设置为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 举报,一经查实,本站将立刻删除。