elasticsearch索引自动清理

查看全部的索引文件:
curl -XGET http://localhost:9200/_cat/indices?vnode

删除索引文件以释放空间:
curl -XDELETE http://localhost:9200/filebeat-2016.12.28shell

单节点的elk可在索引目录删除索引文件:集群环境删除某节点的索引文件,会致使集群服务不可用.集群环境须要使用API的方式进行删除.数组

索引文件保留在服务器中,大大减少服务器的性能,占用硬盘空间,
所以使用脚本自动删除elk中两个月之前的索引以释放空间:bash

--#!/bin/bash服务器

find '/data/elasticsearch/data/elks/nodes/0/indices/' -name 'filebeat-*' -ctime +60 > index.txtcurl

cd ~
cat index.txt | while read line
do
curl -XDELETE "http://localhost:9200/"$(basename $line)""
doneelasticsearch

添加计划任务:
$crontab -e
0 0 * * * cd /root && ./elk_index_remove.sh >>/dev/null性能

ps:shell中单引号&双引号:url

单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的.
单引号字符串中不能出现单引号(对单引号使用转义符后也不能够).code

双引号里能够有变量.
双引号里能够出现转移字符.

使用数组循环删除.
index=(curl -XGET 'http://localhost:9200/_cat/indices/*?v'|awk '{print $3}'|sed '1d')
for i in ${index[*]}:do
curl -XDELETE "http://localhost:9200/$i" done

相关文章
相关标签/搜索