From 51af5374f01987da3a1bd9be86535e432c2b064a Mon Sep 17 00:00:00 2001 From: Sicheng Song Date: Fri, 8 Sep 2023 21:35:13 -0700 Subject: [PATCH] Fix unassigned ml system shard replicas (#1315) * Fix unassigned ml system shard replicas Signed-off-by: Sicheng Song * Adjust auto replica settings to keep it consistent with AOS default setting Signed-off-by: Sicheng Song * Update plugin/src/main/java/org/opensearch/ml/indices/MLIndicesHandler.java Co-authored-by: Yaliang Wu Signed-off-by: Sicheng Song * Modify exception handling Signed-off-by: Sicheng Song * Modify exception messages Signed-off-by: Sicheng Song * Add response check Signed-off-by: Sicheng Song * Add response check and exception handling Signed-off-by: Sicheng Song * Keep error message consistent Signed-off-by: Sicheng Song * Keep error message consistent Signed-off-by: Sicheng Song * Keep error message consistent Signed-off-by: Sicheng Song --------- Signed-off-by: Sicheng Song Co-authored-by: Yaliang Wu (cherry picked from commit 56976e1078e445f27f2358cf066ec45a9d012a9a) --- .../org/opensearch/ml/common/CommonValue.java | 10 +++--- .../ml/indices/MLIndicesHandler.java | 32 ++++++++++++++----- 2 files changed, 29 insertions(+), 13 deletions(-) diff --git a/common/src/main/java/org/opensearch/ml/common/CommonValue.java b/common/src/main/java/org/opensearch/ml/common/CommonValue.java index 16554933b5..dab60ce986 100644 --- a/common/src/main/java/org/opensearch/ml/common/CommonValue.java +++ b/common/src/main/java/org/opensearch/ml/common/CommonValue.java @@ -35,13 +35,13 @@ public class CommonValue { public static final String ML_MODEL_GROUP_INDEX = ".plugins-ml-model-group"; public static final String ML_MODEL_INDEX = ".plugins-ml-model"; public static final String ML_TASK_INDEX = ".plugins-ml-task"; - public static final Integer ML_MODEL_GROUP_INDEX_SCHEMA_VERSION = 1; - public static final Integer ML_MODEL_INDEX_SCHEMA_VERSION = 6; + public static final Integer ML_MODEL_GROUP_INDEX_SCHEMA_VERSION = 2; + public static final Integer ML_MODEL_INDEX_SCHEMA_VERSION = 7; public static final String ML_CONNECTOR_INDEX = ".plugins-ml-connector"; - public static final Integer ML_TASK_INDEX_SCHEMA_VERSION = 1; - public static final Integer ML_CONNECTOR_SCHEMA_VERSION = 1; + public static final Integer ML_TASK_INDEX_SCHEMA_VERSION = 2; + public static final Integer ML_CONNECTOR_SCHEMA_VERSION = 2; public static final String ML_CONFIG_INDEX = ".plugins-ml-config"; - public static final Integer ML_CONFIG_INDEX_SCHEMA_VERSION = 1; + public static final Integer ML_CONFIG_INDEX_SCHEMA_VERSION = 2; public static final String USER_FIELD_MAPPING = " \"" + CommonValue.USER + "\": {\n" diff --git a/plugin/src/main/java/org/opensearch/ml/indices/MLIndicesHandler.java b/plugin/src/main/java/org/opensearch/ml/indices/MLIndicesHandler.java index 12954a62a2..856370eeab 100644 --- a/plugin/src/main/java/org/opensearch/ml/indices/MLIndicesHandler.java +++ b/plugin/src/main/java/org/opensearch/ml/indices/MLIndicesHandler.java @@ -6,8 +6,6 @@ package org.opensearch.ml.indices; import static org.opensearch.ml.common.CommonValue.META; -import static org.opensearch.ml.common.CommonValue.ML_MODEL_INDEX; -import static org.opensearch.ml.common.CommonValue.ML_TASK_INDEX; import static org.opensearch.ml.common.CommonValue.SCHEMA_VERSION_FIELD; import java.util.HashMap; @@ -18,6 +16,7 @@ import org.opensearch.action.admin.indices.create.CreateIndexRequest; import org.opensearch.action.admin.indices.create.CreateIndexResponse; import org.opensearch.action.admin.indices.mapping.put.PutMappingRequest; +import org.opensearch.action.admin.indices.settings.put.UpdateSettingsRequest; import org.opensearch.client.Client; import org.opensearch.cluster.metadata.IndexMetadata; import org.opensearch.cluster.service.ClusterService; @@ -38,11 +37,13 @@ public class MLIndicesHandler { ClusterService clusterService; Client client; - + private static final Map indexSettings = Map.of("index.auto_expand_replicas", "0-5"); private static final Map indexMappingUpdated = new HashMap<>(); + static { - indexMappingUpdated.put(ML_MODEL_INDEX, new AtomicBoolean(false)); - indexMappingUpdated.put(ML_TASK_INDEX, new AtomicBoolean(false)); + for (MLIndex mlIndex : MLIndex.values()) { + indexMappingUpdated.put(mlIndex.getIndexName(), new AtomicBoolean(false)); + } } public void initModelGroupIndexIfAbsent(ActionListener listener) { @@ -83,7 +84,7 @@ public void initMLIndexIfAbsent(MLIndex index, ActionListener listener) log.error("Failed to create index " + indexName, e); internalListener.onFailure(e); }); - CreateIndexRequest request = new CreateIndexRequest(indexName).mapping(mapping); + CreateIndexRequest request = new CreateIndexRequest(indexName).mapping(mapping).settings(indexSettings); client.admin().indices().create(request, actionListener); } else { log.debug("index:{} is already created", indexName); @@ -98,8 +99,23 @@ public void initMLIndexIfAbsent(MLIndex index, ActionListener listener) new PutMappingRequest().indices(indexName).source(mapping, XContentType.JSON), ActionListener.wrap(response -> { if (response.isAcknowledged()) { - indexMappingUpdated.get(indexName).set(true); - internalListener.onResponse(true); + UpdateSettingsRequest updateSettingRequest = new UpdateSettingsRequest(); + updateSettingRequest.indices(indexName).settings(indexSettings); + client + .admin() + .indices() + .updateSettings(updateSettingRequest, ActionListener.wrap(updateResponse -> { + if (response.isAcknowledged()) { + indexMappingUpdated.get(indexName).set(true); + internalListener.onResponse(true); + } else { + internalListener + .onFailure(new MLException("Failed to update index setting for: " + indexName)); + } + }, exception -> { + log.error("Failed to update index setting for: " + indexName, exception); + internalListener.onFailure(exception); + })); } else { internalListener.onFailure(new MLException("Failed to update index: " + indexName)); }