Elasticsearch 限制索引大小与索引模板匹配冲突解决方案

文章目录

  • 背景
  • 介绍
  • 环境
  • 限制索引大小
    • [创建 ILM(索引生命周期管理)策略](#创建 ILM(索引生命周期管理)策略)
      • [创建 ILM 策略](#创建 ILM 策略)
    • [创建索引模板并关联 ILM 策略](#创建索引模板并关联 ILM 策略)
      • [使用索引模板应用 ILM 策略](#使用索引模板应用 ILM 策略)
  • 解决索引模板匹配冲突
    • [✅ 解决方案](#✅ 解决方案)
      • [🔹 方案 1:修改 `index_patterns`(推荐)](#🔹 方案 1:修改 index_patterns(推荐))
      • [🔹 方案 2:提高 `priority`(这个更符合我的方案,但不推荐)](#🔹 方案 2:提高 priority(这个更符合我的方案,但不推荐))
      • [🔹 方案 3:删除已有冲突模板](#🔹 方案 3:删除已有冲突模板)
        • [1️⃣ 查看所有索引模板](#1️⃣ 查看所有索引模板)
        • [2️⃣ 删除不需要的 `metrics` 和 `logs` 模板](#2️⃣ 删除不需要的 metricslogs 模板)
  • 结论

背景

ES 集群每天都会 触发磁盘报警 ,让人 非常头疼

为了控制磁盘使用量,我 编写了一个 Shell 脚本 ,当磁盘 使用率超过 75% 时,就会 自动删除前一天的索引

然而,问题出现了

  • 这些索引 都是当天新产生的 ,导致 脚本无法提前清理,磁盘空间依然告急。

于是,我开始思考:

🔍 Elasticsearch 是否有参数可以直接限制索引大小? 🤔


介绍

在使用 Elasticsearch 时,我们可能需要 限制索引大小 ,以防止磁盘占用过多。通常,我们会使用 索引生命周期管理(ILM)策略 来控制索引的大小,同时需要通过 索引模板(Index Template) 来确保新创建的索引符合规则。

然而,在设置索引模板时,可能会遇到 索引匹配冲突 的问题,导致模板无法生效。本文将介绍 如何限制索引大小 ,并提供 索引模板冲突的解决方案


环境

es集群三台机器

192.168.1.1

192.168.1.2

192.168.1.3


限制索引大小

创建 ILM(索引生命周期管理)策略

ILM 策略允许我们设置 索引的最大大小,并在超出限制时自动滚动到新的索引。

创建 ILM 策略

bash 复制代码
curl -X PUT "192.168.1.1:9200/_ilm/policy/my_policy" -H "Content-Type: application/json" -d '
{
  "policy": {
    "phases": {
      "hot": {
        "actions": {
          "rollover": {
            "max_size": "50gb",  # 单个索引最大 50GB
            "max_age": "7d"      # 或者 7 天后滚动
          }
        }
      }
    }
  }
}'

这个策略的作用:

  • 当索引达到 50GB存活超过 7 天 ,会自动 滚动(rollover) 到新索引。

创建索引模板并关联 ILM 策略

使用索引模板应用 ILM 策略

bash 复制代码
curl -X PUT "192.168.1.1:9200/_index_template/my_template" -H "Content-Type: application/json" -d '
{
  "index_patterns": ["my_index-*"],  # 只匹配 "my_index-" 开头的索引
  "priority": 100,
  "template": {
    "settings": {
      "index.lifecycle.name": "my_policy"
    }
  }
}'

✅ 这样,所有匹配 my_index-* 的索引都会自动遵循 my_policy 策略!


解决索引模板匹配冲突

在上面的操作中,你可能会遇到以下错误:

复制代码
index template [my_template] has index patterns [*] matching patterns from existing templates [metrics,logs]

这个错误的意思是:

  • 你的 index_patterns: ["*"] 匹配了所有索引,而你的集群里已经有 metricslogs 模板 ,并且它们的 priority: 100,导致冲突。

✅ 解决方案

我们可以通过 以下三种方式 解决冲突:

🔹 方案 1:修改 index_patterns(推荐)

最好的做法是 让模板只作用于你需要的索引,而不是所有索引:

bash 复制代码
curl -X PUT "192.168.1.1:9200/_index_template/my_template" -H "Content-Type: application/json" -d '
{
  "index_patterns": ["my_index-*"],  # 只匹配 "my_index-" 开头的索引
  "priority": 100,
  "template": {
    "settings": {
      "index.lifecycle.name": "my_policy"
    }
  }
}'

这样不会影响 metricslogs 索引,避免冲突!


🔹 方案 2:提高 priority(这个更符合我的方案,但不推荐)

如果你仍想让你的模板覆盖所有索引(index_patterns: ["*"]),可以 提高 priority ,比如改成 200

bash 复制代码
curl -X PUT "192.168.1.1:9200/_index_template/my_template" -H "Content-Type: application/json" -d '
{
  "index_patterns": ["*"],
  "priority": 200,  # 提高优先级,覆盖已有模板
  "template": {
    "settings": {
      "index.lifecycle.name": "my_policy"
    }
  }
}'

⚠️ 注意

  • 如果 metricslogs 需要保留原配置,慎用此方法!
  • 推荐方案 1,限制 index_patterns,只作用于部分索引。

🔹 方案 3:删除已有冲突模板

如果 metricslogs 模板不是必须的 ,可以 先查看模板列表,然后删除:

1️⃣ 查看所有索引模板
bash 复制代码
curl -X GET "192.168.1.1:9200/_index_template?pretty"
2️⃣ 删除不需要的 metricslogs 模板
bash 复制代码
curl -X DELETE "192.168.1.1:9200/_index_template/metrics"
curl -X DELETE "192.168.1.1:9200/_index_template/logs"

然后再创建 my_template 模板。

⚠️ 仅适用于 metricslogs 不是你需要的情况下!


结论

方案 适用场景 风险
修改 index_patterns(推荐) 只影响特定索引 最安全
提高 priority 需要全局覆盖 ⚠️ 可能影响现有模板
删除冲突模板 旧模板不再需要 ⚠️ 需确保不会影响系统索引

推荐方案 1 :修改 index_patterns,确保只影响特定索引,避免影响 metricslogs 这些已有模板。

你可以根据自己的需求选择最合适的方案,确保 Elasticsearch 集群稳定运行! 🚀

相关推荐
今生相伴9911 小时前
ELFK:企业级日志管理的完整解决方案——从入门到精通
运维·elk·elasticsearch
在未来等你8 小时前
Elasticsearch面试精讲 Day 15:索引别名与零停机更新
大数据·分布式·elasticsearch·搜索引擎·面试
在未来等你9 小时前
Elasticsearch面试精讲 Day 12:数据建模与字段类型选择
大数据·分布式·elasticsearch·搜索引擎·面试
在未来等你13 小时前
Elasticsearch面试精讲 Day 14:数据写入与刷新机制
大数据·分布式·elasticsearch·搜索引擎·面试
phac12314 小时前
git 如何直接拉去远程仓库的内容且忽略本地与远端不一致的commit
大数据·git·elasticsearch
在未来等你14 小时前
Elasticsearch面试精讲 Day 11:索引模板与动态映射
大数据·分布式·elasticsearch·搜索引擎·面试
哥哥还在IT中14 小时前
Elasticsearch优化从入门到精通
大数据·elasticsearch·搜索引擎
Elastic 中国社区官方博客15 小时前
使用 cloud-native Elasticsearch 与 ECK 运行
大数据·数据库·elasticsearch·搜索引擎·kubernetes·k8s·全文检索
2301_781668611 天前
Elasticsearch 02
大数据·elasticsearch·搜索引擎
赵孝正1 天前
GitLab 分支管理与 Push 问题全解析
大数据·elasticsearch·gitlab