elasticsearch定时删除过期索引index

一、定时函数

每次更新完配置文件后,先清除定时函数。然后设置,每过5s执行一次清理函数

        // 清除定时器
        clearInterval(this.timeObj);
        var config = this.getConfig();
        var keep_time = config.keep_time;
        var obj={
            keep_time:keep_time,
            type:"ops"
        }
        // 定时器定时每5s执行一次
        this.timeObj = setInterval(this.clean,5000, obj);

二、获取过期时间

keep_time:单位天,为设置的索引保存时间,定位到过期时间

        var date = new Date();
        var expiration = new Date(date);
        expiration.setDate(date.getDate() - keep_time);
        // 过期时间
        var expirationTime = expiration.getFullYear() + '/' + (expiration.getMonth() + 1) + '/' + expiration.getDate(); 

三、获取esClient

判定索引是否过期,并收集所有过期的索引。

const es=require("elasticsearch")
const esClient= new es.Client({
    host:'127.0.0.1:9200',
    log:'error'
})
module.exports=esClient

四、获取全部索引

获取所有索引

const getIndex = function getIndex(index) {
            return esClient.indices.get({ index: index })
        }

五、判定索引是否过期

判定索引是否过期,并收集所有过期的索引。

var indexs_delete = []
 for (var index in results) {
                        // 索引时间2020.09.03
                        var dateStr = index.substring(index.length - 10, index.length)
                        // 索引时间 2020/09/03
                        var dateStr = dateStr.replace(/[.]/g, "\/")
                        // 过期时间判定是否过期
                        if (dateStr < expirationTime) {
                            indexs_delete.push(index)
                        }
                    }

六、删除过期索引

删除过期索引。

const indexDelete = function getIndex(index) {
                        return esClient.indices.delete({ index: index })
                    }

七、demo代码

vscode打开代码。在esClient打上断点,打开main.js,按f5运行
demo代码下载
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
您好!对于Elasticsearch定时清理过期索引,您可以使用Elasticsearch的Curator插件来实现。Curator是一个用于管理Elasticsearch索引的工具,可以方便地执行索引删除、备份等操作。 以下是一些步骤可以用来设置定时清理过期索引的任务: 1. 安装Curator:您可以通过pip命令安装Curator: ``` pip install elasticsearch-curator ``` 2. 创建配置文件:创建一个YAML格式的配置文件,用于定义索引清理任务。例如,创建一个名为`curator_config.yml`的文件,并添加以下内容: ```yaml --- # 连接Elasticsearch的信息 client: hosts: - 127.0.0.1 port: 9200 url_prefix: use_ssl: False certificate: client_cert: client_key: ssl_no_validate: False http_auth: timeout: 30 master_only: False # 清理任务配置 actions: 1: action: delete_indices description: "Delete indices older than 30 days" filters: - filtertype: pattern kind: prefix value: your_index_prefix- - filtertype: age source: name direction: older timestring: '%Y.%m.%d' unit: days unit_count: 30 ``` 在上述配置中,`hosts`字段指定了Elasticsearch的地址和端口,`filters`字段定义了过滤器规则,这里以索引名的前缀和索引的创建时间进行过滤。 3. 创建定时任务:使用cron表达式来定义定时任务,可以在Linux系统的crontab中添加以下命令: ``` curator --config /path/to/curator_config.yml --dry-run ``` 上述命令中的`--dry-run`参数用于测试运行,可以在实际运行之前先检查将要执行的操作。 4. 运行定时任务:如果测试运行没有问题,可以将上述命令添加到crontab中,并设置合适的执行频率。例如,每天凌晨执行一次: ``` 0 0 * * * curator --config /path/to/curator_config.yml ``` 通过以上步骤,您就可以设置定时清理过期索引的任务了。请确保对配置文件和定时任务的设置进行适当调整,以满足您的需求。希望对您有所帮助!如有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郑同学的笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值