Easysearch 索引生命周期管理实战

如果你的使用场景是对时序型数据进行分析,可能你会更重视最新的数据,并且可能会定期对老旧的数据进行一些处理,比如减少副本数、forcemerge、 删除等。Easysearch 的索引生命周期管理功能,可以自动完成此类索引的管理任务。
创建策略
为了演示,我们定义一个简单的索引策略:
索引创建后进入 hot 阶段,此阶段的索引有 2 个副本(在索引模板中定义)
创建索引 3 分钟后,进入 warm 阶段,此阶段的索引有 1 个副本
创建索引 10 分钟后,进入 cold 阶段,此阶段的索引没有副本
当然每个阶段还支持更多的操作,比如 rollover、forcemerge、readonly、snapshot 等。更多的信息请查看官方文档。
生命周期策略后台是定期触发的任务,为了更快的观测到效果,可以修改任务触发周期为每分钟 1 次。
创建索引模板
创建完索引生命周期策略,还需要索引模板把索引和生命周期策略关联起来,这样只要创建相关索引就自动会被生命周期策略管理。我们创建一个模板把所有 ilm_test 开头的索引与 ilm_test 生命周期策略关联,并指定索引创建时就有 2 个副本。
创建初始索引
创建一个 ilm_test 开头的索引,应用上一步创建的索引模板。
17 点 50 分 44 秒创建初始索引,索引分片情况是 1 个主分片和 2 个副本分片,每个节点一个分片。


3 分钟后,17 点 53 分 55 秒,索引进入 warm 阶段,副本数变成 1,剩下一个 主分片和 1 个副本分片。


又 7 分钟后(距索引创建 10 分钟),18 点 00 分 46 秒,索引进入 cold 阶段,副本数变成 0,只剩下一个主分片。


至此索引的生命周期完成。
更新策略
更新 ILM 策略需要在请求 url 里指定 seq_no 和 primary_term 。修改前先查看当前策略的 seq_no 和 primary_term。

修改策略 ilm_test,使 cold 阶段保持 2 个副本。

更新成功。
⚠️ 注意:更新索引生命周期策略不会对当前正在管理的索引造成影响(包括删除策略重建),只会影响新生成的索引。
删除策略
通过指定策略命删除策略
版权声明: 本文为 InfoQ 作者【极限实验室】的原创文章。
原文链接:【http://xie.infoq.cn/article/bea75e1d7c66c5e2e75d3cfe7】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论