首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除elasticsearch中超过30天的文档

删除elasticsearch中超过30天的文档
EN

Stack Overflow用户
提问于 2016-03-29 15:05:04
回答 1查看 41K关注 0票数 12

我想在我的elasticsearch索引中删除超过30天的文档。

有什么想法吗?

编辑:

我希望这是自动发生的-在我的索引中没有任何文档应该超过30天。因此,在我看来,有两个选择:要么使用策展人或删除请求。

我两者都试过了,但都失败了。不知何故,当我使用DELETE http语句时,我必须创建一个过滤器来过滤所有超过30天的文档并删除它们。

我试过了策展人,但策展人(据我所知)只删除整个索引。当我试图用策展人删除超过30天的索引时,我的时间戳导致了errors.My moment.js模式,类似于这个"MMMM Do YYYY, HH:mm:ss.SSS"

编辑2:我在logstash配置中添加了以下内容:

代码语言:javascript
复制
elasticsearch
    {
    hosts => ["http://localhost:9200"]
    index => "logstash-%{type}-%{+YYYY.MM.dd}"
    document_type => "%{[@metadata][type]}"
    }

因此logstash为每种类型和每一天创建一个特定的索引。现在,我可以使用策展人删除比特定日期更早的索引。

问题解决了,白痴。

EN

回答 1

Stack Overflow用户

发布于 2016-03-29 15:24:04

您可以使用DELETE查询:https://www.elastic.co/guide/en/elasticsearch/reference/1.6/docs-delete-by-query.html,例如,查询将删除所有比: 2016-02-29更老的内容。

代码语言:javascript
复制
DELETE index_name/_query
{
  "query": {
    "filtered": {
      "query": {
        "query_string": {
          "query": "*"
        }
      },
      "filter": {
        "range": {
          "@timestamp": {
            "lte": "2016-02-29"
          }
        }
      }
    }
  }
}

更新>6.4

根据官方文档,这个功能已经被_delete_by_query取代了。

代码语言:javascript
复制
POST index_name/_delete_by_query
{
  "query": { 
    "match": {
      "message": "some message"
    }
  }
}

https://www.elastic.co/guide/en/elasticsearch/reference/current/docs-delete-by-query.html

票数 29
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36288078

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档