创建及管理OpenSearch索引策略
本文介绍如何创建和管理OpenSearch集群的生命周期索引策略。
背景信息
OpenSearch的ISM(Index State Management)是一个索引状态管理插件,支持通过索引使用期限、索引大小或文档数等信息的变化来自动触发周期性的管理操作。通过ISM插件可以自定义索引策略,实现自动处理索引的滚动或删除,以优化集群搜索性能或降低存储成本。ISM的使用流程:
- 创建生命周期策略:在Kibana创建索引的生命周期策略Policy。
- 索引关联生命周期策略:将索引关联上创建的生命周期策略,生成索引策略。
- 管理索引策略:支持对索引策略进行策略修改、重启和变更。
ISM更多功能请参见索引管理官方介绍。
创建的索引生命周期策略常用于以下场景:通过索引生命周期管理实现OpenSearch集群自动滚动索引
创建生命周期策略
- 登录云搜索服务管理控制台。
- 在“集群管理”页面选择需要登录的集群,单击“操作”列中的“Kibana”。
- 登录OpenSearch Dashboard,在左侧选择“Index Management”,进入索引管理页面 。
- 右侧单击Create policy,创建索引策略。在Configuration method对话框中,选择“JSON editor”,单击“Continue”进入创建索引策略页面。
- “Policy ID”:自定义策略名称。
- “Define policy”:基于策略示例,配置自定义策略。
图1 配置策略
- 单击Create完成索引策略的创建。
索引关联生命周期策略
创建索引策略后,可以将此策略附加到一个或多个索引,匹配该索引模板创建出的索引都将被附加该策略。
- 方式1:OpenSearch Dashboard命令行
在OpenSearch Dashboard的“Dev Tools”页面,执行如下命令在索引模板中关联策略ID。
PUT _template/<template_name> { "index_patterns": ["index_name-*"], "settings": { "opendistro.index_state_management.policy_id": "policy_id" } }
- <template_name>:需要替换为创建的索引模板名。
- policy_id:需要替换为自定义的策略ID,即“Policy ID”。
更多创建索引模板的说明可参考索引模板。
- 方式2:OpenSearch Dashboard控制台
- 在OpenSearch Dashboard的“Index Management”页面,选择Indices。
图2 选择Indices
- 在Indices列表中选择您要附加策略的一个或多个索引。
- 单击右上角的“Apply policy”,在弹窗中选择要关联的“Policy ID”。
图3 添加引用策略
图4 选择索引策略
- 单击“Apply”,完成索引关联策略。
当索引关联策略后,ISM会默认创建一个每5分钟运行一次的作业,用于执行策略操作、检查条件并将索引转换为不同的状态。
- 在OpenSearch Dashboard的“Index Management”页面,选择Indices。
管理索引策略
- 在OpenSearch Dashboard的“Index Management”页面,选择“Managed Indices”,进入索引策略管理列表。
此处会展示当前集群已配置的索引策略。
- 在索引策略管理列表,管理策略。
- 当索引的策略状态异常时,可以勾选状态异常的索引,单击“Retry policy”,可以重试策略。
- 当需要更新索引的策略时,可以勾选索引,单击“Change policy”进入变更策略页面,更新策略后,单击“Change”变更策略。
- 当需要解除索引的策略时,可以勾选索引,单击“Remove policy”,在弹窗确认后单击“Remove”该索引将被解除策略。
具体使用可参考索引管理官方介绍。