开发者社区 > 大数据与机器学习 > 检索分析服务 Elasticsearch版 > 正文

Elasticsearch用生命周期来删除该索引被标注为删除但没有被立刻删掉,段合并时间在哪设置?

Elasticsearch用生命周期来删除该索引被标注为删除但没有被立刻删掉,段合并时间在哪设置?
iwEcAqNwbmcDAQTRAUwFNQawi8Y2ZLsq4wQFNp5YbYAUAAfSJfw74AgACaJpbQoAC9EUpA.png_720x720q90.jpg

展开
收起
青城山下庄文杰 2023-11-05 16:32:18 261 0
2 条回答
写回答
取消 提交回答
  • 在Elasticsearch中,段合并是由内部管理的,不需要手动设置。然而,你可以通过修改Elasticsearch的配置来调整段合并的时间间隔。

    要修改段合并的时间间隔,可以调整index.merge.policy设置。具体来说,可以设置index.merge.policy.max_merge_at_once参数来控制一次可以合并的最大段数,以及index.merge.policy.min_merge_size参数来控制最小的合并大小。

    此外,你还可以通过执行DELETE索引API来删除一个索引。要删除整个索引,可以使用以下命令:

    DELETE /<index_name>
    

    请注意,执行这个命令将永久删除该索引及其所有数据。

    如果Elasticsearch版本不支持DELETE索引API和查询参数,可以考虑安装delete_by_query插件。安装完插件后,可以执行以下命令删除文档:

    POST /<index_name>/_delete_by_query
    {
      "query": {
        <your_query>
      }
    }
    

    请将<index_name>替换为你要删除的索引名称,<your_query>替换为你要删除的文档的查询条件。

    2023-11-06 10:49:01
    赞同 展开评论 打赏
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    在 Elasticsearch 中,当索引被标记为已删除后,它并不会立即从磁盘上删除,而是会进入一个所谓的 "删除状态"。这个过程是为了防止突然丢失数据,并在一段时间内仍然保留索引文件以备恢复。在删除状态下,Elasticsearch 不会再使用这部分磁盘空间,但也不会立即释放空间。
    关于索引何时从磁盘上真正删除的时间,由一个称为 "段合并" 的过程决定。在段合并过程中,Elasticsearch 会定期检查删除状态下的索引,如果发现有足够的删除状态下的索引,就会合并它们并将释放的空间返还给操作系统。在 Elasticsearch 中,可以通过修改 indices.store.throttle.type 配置项来控制段合并的速度。
    在实践中,一般情况下,Elasticsearch 可能需要几个小时甚至几天才能完全删除已被标记为已删除的索引。具体时间取决于你的集群规模、数据量和段合并的速度等因素。如果希望加速删除过程,可以考虑提高段合并速度或限制索引数量,以便更快地触发段合并。

    2023-11-05 16:35:30
    赞同 展开评论 打赏

阿里云检索分析服务Elasticsearch版兼容开源ELK功能,免运维全托管,提升企业数据检索与运维分析能力。

相关产品

  • 检索分析服务 Elasticsearch版
  • 热门讨论

    热门文章

    相关电子书

    更多
    阿里云Elasticsearch体系架构与特性解析 立即下载
    开源与云:Elasticsearch应用剖析 立即下载
    《Elasticsearch全观测解决方案》 立即下载