探究 | Elasticsearch如何物理删除给定期限的历史数据?

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: 1、题记想到删除,基础认知是delete,细分为删除文档(document)和删除索引;要删除历史数据,基础认知是:删除了给定条件的数据,用delete_by_query。实际操作发现:- 删除文档后,磁盘空间并没有立即减少,反而增加了?- 除了定时任务+delete_by_query,有没有更好的方式呢?

2、常见的删除操作

2.1 删除单个文档

DELETE /twitter/_doc/1

1

2.2 删除满足给定条件的文档

POST twitter/_delete_by_query

{

 "query": {

   "match": {

     "message": "some message"

   }

 }

}

1

2

3

4

5

6

7

8

注意:执行批量删除的时候,可能会发生版本冲突。强制执行删除的方式如下:


POST twitter/_doc/_delete_by_query?conflicts=proceed

{

 "query": {

   "match_all": {}

 }

}

1

2

3

4

5

6

2.3 删除单个索引

DELETE /twitter

1

2.4 删除所有索引

DELETE /_all

1

或者


DELETE /*

1

删除所有索引是非常危险的操作,要注意谨慎操作。


3、删除文档后台做了什么?

执行删除后的返回结果:


{

 "_index": "test_index",

 "_type": "test_type",

 "_id": "22",

 "_version": 2,

 "result": "deleted",

 "_shards": {

   "total": 2,

   "successful": 1,

   "failed": 0

 },

 "_seq_no": 2,

 "_primary_term": 17

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

解读:


索引的每个文档都是版本化的。

删除文档时,可以指定版本以确保我们试图删除的相关文档实际上被删除,并且在此期间没有更改。


每个在文档上执行的写操作,包括删除,都会使其版本增加。


真正的删除时机:


deleting a document doesn’t immediately remove the document from disk; it just marks it as deleted. Elasticsearch will clean up deleted documents in the background as you continue to index more data.


4、删除索引和删除文档的区别?

1)删除索引是会立即释放空间的,不存在所谓的“标记”逻辑。


2)删除文档的时候,是将新文档写入,同时将旧文档标记为已删除。 磁盘空间是否释放取决于新旧文档是否在同一个segment file里面,因此ES后台的segment merge在合并segment file的过程中有可能触发旧文档的物理删除。


但因为一个shard可能会有上百个segment file,还是有很大几率新旧文档存在于不同的segment里而无法物理删除。想要手动释放空间,只能是定期做一下force merge,并且将max_num_segments设置为1。


POST /_forcemerge

1

5、如何仅保存最近100天的数据?

有了上面的认知,仅保存近100天的数据任务分解为:

- 1)delete_by_query设置检索近100天数据;

- 2)执行forcemerge操作,手动释放磁盘空间。


删除脚本如下:


#!/bin/sh

curl -H'Content-Type:application/json' -d'{

   "query": {

       "range": {

           "pt": {

               "lt": "now-100d",

               "format": "epoch_millis"

           }

       }

   }

}

' -XPOST "http://192.168.1.101:9200/logstash_*/

_delete_by_query?conflicts=proceed"

1

2

3

4

5

6

7

8

9

10

11

12

13

merge脚本如下:


#!/bin/sh

curl -XPOST 'http://192.168.1.101:9200/_forcemerge?

only_expunge_deletes=true&max_num_segments=1'

1

2

3

6、有没有更通用的方法?

有,使用ES官网工具——curator工具。


6.1 curator简介

主要目的:规划和管理ES的索引。支持常见操作:创建、删除、合并、reindex、快照等操作。


6.2 curator官网地址

http://t.cn/RuwN0oM


Git地址:https://github.com/elastic/curator


6.3 curator安装向导

地址:http://t.cn/RuwCkBD


注意:

curator各种博客教程层出不穷,但curator旧版本和新版本有较大差异,建议参考官网最新手册部署。

旧版本命令行方式新版本已不支持。


6.4 curator命令行操作

$ curator --help

Usage: curator [OPTIONS] ACTION_FILE


 Curator for Elasticsearch indices.


 See http://elastic.co/guide/en/elasticsearch/client/curator/current


Options:

 --config PATH  Path to configuration file. Default: ~/.curator/curator.yml

 --dry-run      Do not perform any changes.

 --version      Show the version and exit.

 --help         Show this message and exit.

1

2

3

4

5

6

7

8

9

10

11

12

核心:

- 配置文件config.yml:配置要连接的ES地址、日志配置、日志级别等;


执行文件action.yml: 配置要执行的操作(可批量)、配置索引的格式(前缀匹配、正则匹配方式等)

6.5 curator适用场景

最重要的是:


仅以删除操作为例:curator可以非常简单地删除x天后的索引的前提是:索引命名要遵循特定的命名模式——如:以天为命名的索引:logstash_2018.04.05。


命名模式需要和action.yml中的delete_indices下的timestring对应。


7、小结

多参考官网最新的文档,历史版本的历史文档很容易误导人;

多真正去实践,而不是仅限于知道;

medcl:ES新版本6.3 有一个 Index LifeCycle Management 可以很方便的管理索引的保存期限。

相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
相关文章
|
6月前
|
API 网络架构 索引
Elasticsearch索引中数据的增删改查与并发控制
Elasticsearch索引中数据的增删改查与并发控制
|
6月前
|
存储 监控 数据挖掘
使用 Meltano 将数据从 Snowflake 导入到 Elasticsearch:开发者之旅
【6月更文挑战第9天】Meltano,一个开源数据集成框架,简化了从Snowflake到Elasticsearch的数据迁移。这个工具支持多种数据源,提供易于配置的界面。要开始,需安装Meltano并配置连接信息。一个简单的YAML示例展示了如何定义从Snowflake到Elasticsearch的迁移任务。Meltano自动执行迁移,同时提供监控和日志功能。借助Meltano,用户能高效集成数据,提升搜索和分析能力,适应不断增长的数据需求和挑战。
106 6
|
2月前
|
Web App开发 JavaScript Java
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
这篇文章是关于如何使用Spring Boot整合Elasticsearch,并通过REST客户端操作Elasticsearch,实现一个简单的搜索前后端,以及如何爬取京东数据到Elasticsearch的案例教程。
217 0
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
|
2月前
|
消息中间件 监控 关系型数据库
MySQL数据实时同步到Elasticsearch:技术深度解析与实践分享
在当今的数据驱动时代,实时数据同步成为许多应用系统的核心需求之一。MySQL作为关系型数据库的代表,以其强大的事务处理能力和数据完整性保障,广泛应用于各种业务场景中。然而,随着数据量的增长和查询复杂度的提升,单一依赖MySQL进行高效的数据检索和分析变得日益困难。这时,Elasticsearch(简称ES)以其卓越的搜索性能、灵活的数据模式以及强大的可扩展性,成为处理复杂查询需求的理想选择。本文将深入探讨MySQL数据实时同步到Elasticsearch的技术实现与最佳实践。
135 0
|
4月前
|
存储 缓存 监控
|
4月前
|
自然语言处理 索引
ElasticSearch 实现分词全文检索 - 测试数据准备
ElasticSearch 实现分词全文检索 - 测试数据准备
54 1
|
4月前
|
数据采集 人工智能 自然语言处理
阿里云Elasticsearch AI语义搜索:解锁未来搜索新纪元,精准洞察数据背后的故事!
【8月更文挑战第2天】阿里云Elasticsearch AI场景语义搜索最佳实践
215 5
|
5月前
|
存储 安全 文件存储
【elasticsearch】es6重启服务后数据消失,es6如何配置数据持久化储存
【elasticsearch】es6重启服务后数据消失,es6如何配置数据持久化储存
57 1
|
6月前
|
索引
利用滚动索引来管理海量Elasticsearch数据
利用滚动索引来管理海量Elasticsearch数据
110 3
|
6月前
|
数据库 索引
Elasticsearch索引别名:管理与优化数据访问
Elasticsearch索引别名:管理与优化数据访问