ES索引数据清理脚本示例

说明:我得索引是按月份创建的,索引名后面都有yyyy.MM

需求:删除三个月以前的索引,清理收集的应用日志数据,释放磁盘空间 

 1、

#!/bin/bash

# 定义 Elasticsearch 节点的地址
ELASTICSEARCH_HOST="192.168.53.100"
ELASTICSEARCH_PORT="9200"

# 计算三个月之前的年月
THREE_MONTHS_AGO=$(date -d "3 months ago" +"%Y.%m")

# 要清理的索引前缀
INDEX_PREFIXES=("myapp" "ruoyiapp")

# 循环遍历索引前缀
for prefix in "${INDEX_PREFIXES[@]}"
do
    # 构建索引名称
    INDEX_NAME="$prefix-$THREE_MONTHS_AGO"
    
    # 使用 curl 发送删除索引的请求
    curl -X DELETE "$ELASTICSEARCH_HOST:$ELASTICSEARCH_PORT/$INDEX_NAME"
done

在此示例中,我们定义了 Elasticsearch 节点的地址和端口。然后,我们使用 date 命令计算了三个月之前的年月,并将其存储在变量 THREE_MONTHS_AGO 中。接着,我们定义了一个包含要清理的索引前缀的数组 INDEX_PREFIXES,然后使用循环遍历该数组,构建索引名称并使用 curl 发送 DELETE 请求来删除指定的索引。

请注意,由于日期计算可能因操作系统而异,以上示例中的日期计算部分(date -d "3 months ago" +"%Y.%m")可能需要根据您的操作系统进行相应的修改。另外,请根据实际情况修改脚本中的 Elasticsearch 节点地址。由于删除操作可能对数据造成永久性影响,请务必在生产环境中谨慎使用。

2、

#!/bin/bash

# 获取当前日期的三个月之前的日期
three_months_ago=$(date -d "-3 months" +%Y.%m.%d)

HOST="192.168.53.100"
PORT="9200"
USER=elastic
PASSWD=elas#123

# 定义要查找的索引前缀数组
index_prefixes=("prefix1" "prefix2" "prefix3")

# 连接Elasticsearch并获取所有索引名称
indices=$(curl -u $USER:$PASSWD -s -XGET "$HOST:$PORT/_cat/indices?v" | awk '{print $3}')

# 循环遍历每个索引前缀
for prefix in "${index_prefixes[@]}"
do
  # 过滤出指定前缀的索引
  filtered_indices=$(echo "$indices" | grep "$prefix")
  
  # 循环遍历索引并删除三个月之前及更早的索引
  for index in $filtered_indices
  do
    index_date=$(echo $index | awk -F "-" '{print $NF}')
    if [[ $index_date < $three_months_ago ]]; then
      echo "Deleting index: $index"
      curl -u $USER:$PASSWD -X DELETE "$HOST:$PORT/$index"
    fi
  done
done

 

posted @ 2023-11-17 11:13  太阳的阳ฅ  阅读(111)  评论(0编辑  收藏  举报