[DOCS] add comment to clarify cluster name resolution (#34014)

We currently fallback to local indices whenever a remote cluster is not found, as there may still be indices / aliases with the same name. Such behaviour is lenient but needs to be kept for backwards compatibility. Clarified that in the code so we don't forget.

Relates to #26247
This commit is contained in:
Luca Cavanna 2018-09-25 14:03:07 +02:00 committed by GitHub
parent dfe5af0411
commit 970407c663
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 7 additions and 3 deletions

View File

@ -231,9 +231,10 @@ public abstract class RemoteClusterAware extends AbstractComponent {
List<String> clusters = clusterNameResolver.resolveClusterNames(remoteClusterNames, remoteClusterName); List<String> clusters = clusterNameResolver.resolveClusterNames(remoteClusterNames, remoteClusterName);
if (clusters.isEmpty() == false) { if (clusters.isEmpty() == false) {
if (indexExists.test(index)) { if (indexExists.test(index)) {
// we use : as a separator for remote clusters. might conflict if there is an index that is actually named //We use ":" as a separator for remote clusters. There may be a conflict if there is an index that is named
// remote_cluster_alias:index_name - for this case we fail the request. the user can easily change the cluster alias //remote_cluster_alias:index_name - for this case we fail the request. The user can easily change the cluster alias
// if that happens //if that happens. Note that indices and aliases can be created with ":" in their names names up to 6.last, which
//means such names need to be supported until 7.last. It will be possible to remove this check from 8.0 on.
throw new IllegalArgumentException("Can not filter indices; index " + index + throw new IllegalArgumentException("Can not filter indices; index " + index +
" exists but there is also a remote cluster named: " + remoteClusterName); " exists but there is also a remote cluster named: " + remoteClusterName);
} }
@ -242,6 +243,9 @@ public abstract class RemoteClusterAware extends AbstractComponent {
perClusterIndices.computeIfAbsent(clusterName, k -> new ArrayList<>()).add(indexName); perClusterIndices.computeIfAbsent(clusterName, k -> new ArrayList<>()).add(indexName);
} }
} else { } else {
//Indices and aliases can be created with ":" in their names up to 6.last (although deprecated), and still be
//around in 7.x. That's why we need to be lenient here and treat the index as local although it contains ":".
//It will be possible to remove such leniency and assume that no local indices contain ":" only from 8.0 on.
perClusterIndices.computeIfAbsent(RemoteClusterAware.LOCAL_CLUSTER_GROUP_KEY, k -> new ArrayList<>()).add(index); perClusterIndices.computeIfAbsent(RemoteClusterAware.LOCAL_CLUSTER_GROUP_KEY, k -> new ArrayList<>()).add(index);
} }
} else { } else {