Remove remaining line length violations in o.e.cluster (#34941)
relates #34923, #34884
This commit is contained in:
parent
d85a654ebb
commit
5dda2b0c7a
|
@ -89,40 +89,6 @@
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]update[/\\]TransportUpdateAction.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]update[/\\]TransportUpdateAction.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]update[/\\]UpdateRequest.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]update[/\\]UpdateRequest.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]update[/\\]UpdateRequestBuilder.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]update[/\\]UpdateRequestBuilder.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ClusterStateObserver.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ClusterStateUpdateTask.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]DiffableUtils.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]IncompatibleClusterStateVersionException.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]InternalClusterInfoService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]LocalNodeMasterListener.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]action[/\\]index[/\\]NodeMappingRefreshAction.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]action[/\\]shard[/\\]ShardStateAction.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]block[/\\]ClusterBlock.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]AliasOrIndex.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]AutoExpandReplicas.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]IndexMetaData.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]IndexNameExpressionResolver.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaData.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaDataCreateIndexService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaDataIndexStateService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaDataIndexUpgradeService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaDataMappingService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaDataUpdateSettingsService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]RepositoriesMetaData.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]IndexRoutingTable.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]IndexShardRoutingTable.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]OperationRouting.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]RoutingNodes.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]RoutingService.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]RoutingTable.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]ShardRouting.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]allocator[/\\]BalancedShardsAllocator.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]command[/\\]AbstractAllocateAllocationCommand.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]command[/\\]AllocateEmptyPrimaryAllocationCommand.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]command[/\\]AllocateReplicaAllocationCommand.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]command[/\\]AllocationCommands.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]command[/\\]MoveAllocationCommand.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]decider[/\\]AllocationDeciders.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]index[/\\]CompositeIndexEventListener.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]index[/\\]CompositeIndexEventListener.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]index[/\\]IndexSettings.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]index[/\\]IndexSettings.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]index[/\\]MergePolicyConfig.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]main[/\\]java[/\\]org[/\\]elasticsearch[/\\]index[/\\]MergePolicyConfig.java" checks="LineLength" />
|
||||||
|
@ -252,75 +218,6 @@
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]termvectors[/\\]MultiTermVectorsIT.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]termvectors[/\\]MultiTermVectorsIT.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]termvectors[/\\]TermVectorsUnitTests.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]action[/\\]termvectors[/\\]TermVectorsUnitTests.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]aliases[/\\]IndexAliasesIT.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]aliases[/\\]IndexAliasesIT.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ClusterHealthIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ClusterInfoServiceIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ClusterStateDiffIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]DiskUsageTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]MinimumMasterNodesIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]NoMasterNodeIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]SimpleClusterStateIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]SimpleDataNodesIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]SpecificMasterNodesIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]UpdateSettingsValidationIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ack[/\\]AckClusterUpdateSettingsIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]ack[/\\]AckIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]action[/\\]shard[/\\]ShardFailedClusterStateTaskExecutorTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]action[/\\]shard[/\\]ShardStateActionTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]allocation[/\\]AwarenessAllocationIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]allocation[/\\]ClusterRerouteIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]allocation[/\\]FilteringAllocationIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]allocation[/\\]SimpleAllocationIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]health[/\\]ClusterIndexHealthTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]AutoExpandReplicasTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]DateMathExpressionResolverTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]HumanReadableIndexSettingsTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]IndexNameExpressionResolverTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]MetaDataTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]ToAndFromJsonMetaDataTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]metadata[/\\]WildcardExpressionResolverTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]AllocationIdTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]DelayedAllocationIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]PrimaryAllocationIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]RoutingTableTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]ShardRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]UnassignedInfoTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]AddIncrementallyTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]AllocationCommandsTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]AllocationPriorityTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]AwarenessAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]BalanceConfigurationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ClusterRebalanceRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ConcurrentRebalanceRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]DeadNodesAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ElectReplicaAsPrimaryDuringRelocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ExpectedShardSizeAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]FailedNodeRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]FailedShardsRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]IndexBalanceTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]NodeVersionAllocationDeciderTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]PreferLocalPrimariesToRelocatingPrimariesTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]PreferPrimaryAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]PrimaryElectionRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]PrimaryNotRelocatedWhileBeingRecoveredTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]RandomAllocationDeciderTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]RebalanceAfterActiveTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ReplicaAllocatedAfterPrimaryTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]RoutingNodesIntegrityTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ShardVersioningTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ShardsLimitAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]SingleShardNoReplicasRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]SingleShardOneReplicaRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]StartedShardsRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]TenShardsOneReplicaRoutingTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]ThrottlingAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]UpdateNumberOfReplicasTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]decider[/\\]DiskThresholdDeciderUnitTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]routing[/\\]allocation[/\\]decider[/\\]EnableAllocationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]serialization[/\\]ClusterSerializationTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]serialization[/\\]DiffableTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]settings[/\\]ClusterSettingsIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]shards[/\\]ClusterSearchShardsIT.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]cluster[/\\]structure[/\\]RoutingIteratorTests.java" checks="LineLength" />
|
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]deps[/\\]joda[/\\]SimpleJodaTests.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]deps[/\\]joda[/\\]SimpleJodaTests.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]env[/\\]EnvironmentTests.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]env[/\\]EnvironmentTests.java" checks="LineLength" />
|
||||||
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]env[/\\]NodeEnvironmentTests.java" checks="LineLength" />
|
<suppress files="server[/\\]src[/\\]test[/\\]java[/\\]org[/\\]elasticsearch[/\\]env[/\\]NodeEnvironmentTests.java" checks="LineLength" />
|
||||||
|
|
|
@ -216,7 +216,8 @@ public class ClusterStateObserver {
|
||||||
lastObservedState.set(new StoredState(newState));
|
lastObservedState.set(new StoredState(newState));
|
||||||
context.listener.onNewClusterState(newState);
|
context.listener.onNewClusterState(newState);
|
||||||
} else {
|
} else {
|
||||||
logger.trace("observer: postAdded - predicate approved state but observing context has changed - ignoring ({})", newState);
|
logger.trace("observer: postAdded - predicate approved state but observing context has changed - ignoring ({})",
|
||||||
|
newState);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
logger.trace("observer: postAdded - predicate rejected state ({})", newState);
|
logger.trace("observer: postAdded - predicate rejected state ({})", newState);
|
||||||
|
@ -240,7 +241,8 @@ public class ClusterStateObserver {
|
||||||
if (context != null) {
|
if (context != null) {
|
||||||
clusterApplierService.removeTimeoutListener(this);
|
clusterApplierService.removeTimeoutListener(this);
|
||||||
long timeSinceStartMS = TimeValue.nsecToMSec(System.nanoTime() - startTimeNS);
|
long timeSinceStartMS = TimeValue.nsecToMSec(System.nanoTime() - startTimeNS);
|
||||||
logger.trace("observer: timeout notification from cluster service. timeout setting [{}], time since start [{}]", timeOutValue, new TimeValue(timeSinceStartMS));
|
logger.trace("observer: timeout notification from cluster service. timeout setting [{}], time since start [{}]",
|
||||||
|
timeOutValue, new TimeValue(timeSinceStartMS));
|
||||||
// update to latest, in case people want to retry
|
// update to latest, in case people want to retry
|
||||||
lastObservedState.set(new StoredState(clusterApplierService.state()));
|
lastObservedState.set(new StoredState(clusterApplierService.state()));
|
||||||
timedOut = true;
|
timedOut = true;
|
||||||
|
|
|
@ -29,7 +29,7 @@ import java.util.List;
|
||||||
* A task that can update the cluster state.
|
* A task that can update the cluster state.
|
||||||
*/
|
*/
|
||||||
public abstract class ClusterStateUpdateTask
|
public abstract class ClusterStateUpdateTask
|
||||||
implements ClusterStateTaskConfig, ClusterStateTaskExecutor<ClusterStateUpdateTask>, ClusterStateTaskListener {
|
implements ClusterStateTaskConfig, ClusterStateTaskExecutor<ClusterStateUpdateTask>, ClusterStateTaskListener {
|
||||||
|
|
||||||
private final Priority priority;
|
private final Priority priority;
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ public abstract class ClusterStateUpdateTask
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final ClusterTasksResult<ClusterStateUpdateTask> execute(ClusterState currentState, List<ClusterStateUpdateTask> tasks)
|
public final ClusterTasksResult<ClusterStateUpdateTask> execute(ClusterState currentState, List<ClusterStateUpdateTask> tasks)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
ClusterState result = execute(currentState);
|
ClusterState result = execute(currentState);
|
||||||
return ClusterTasksResult.<ClusterStateUpdateTask>builder().successes(tasks).build(result);
|
return ClusterTasksResult.<ClusterStateUpdateTask>builder().successes(tasks).build(result);
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,7 +74,8 @@ public class OperationRouting extends AbstractComponent {
|
||||||
return shards(clusterState, index, id, routing).shardsIt();
|
return shards(clusterState, index, id, routing).shardsIt();
|
||||||
}
|
}
|
||||||
|
|
||||||
public ShardIterator getShards(ClusterState clusterState, String index, String id, @Nullable String routing, @Nullable String preference) {
|
public ShardIterator getShards(ClusterState clusterState, String index, String id, @Nullable String routing,
|
||||||
|
@Nullable String preference) {
|
||||||
return preferenceActiveShardIterator(shards(clusterState, index, id, routing), clusterState.nodes().getLocalNodeId(),
|
return preferenceActiveShardIterator(shards(clusterState, index, id, routing), clusterState.nodes().getLocalNodeId(),
|
||||||
clusterState.nodes(), preference, null, null);
|
clusterState.nodes(), preference, null, null);
|
||||||
}
|
}
|
||||||
|
|
|
@ -198,8 +198,9 @@ public class SimpleClusterStateIT extends ESIntegTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLargeClusterStatePublishing() throws Exception {
|
public void testLargeClusterStatePublishing() throws Exception {
|
||||||
int estimatedBytesSize = scaledRandomIntBetween(ByteSizeValue.parseBytesSizeValue("10k", "estimatedBytesSize").bytesAsInt(),
|
int estimatedBytesSize = scaledRandomIntBetween(
|
||||||
ByteSizeValue.parseBytesSizeValue("256k", "estimatedBytesSize").bytesAsInt());
|
ByteSizeValue.parseBytesSizeValue("10k", "estimatedBytesSize").bytesAsInt(),
|
||||||
|
ByteSizeValue.parseBytesSizeValue("256k", "estimatedBytesSize").bytesAsInt());
|
||||||
XContentBuilder mapping = XContentFactory.jsonBuilder().startObject().startObject("type").startObject("properties");
|
XContentBuilder mapping = XContentFactory.jsonBuilder().startObject().startObject("type").startObject("properties");
|
||||||
int counter = 0;
|
int counter = 0;
|
||||||
int numberOfFields = 0;
|
int numberOfFields = 0;
|
||||||
|
@ -281,7 +282,8 @@ public class SimpleClusterStateIT extends ESIntegTestCase {
|
||||||
// ignore_unavailable set to false throws exception when allowNoIndices is turned off
|
// ignore_unavailable set to false throws exception when allowNoIndices is turned off
|
||||||
IndicesOptions allowNoIndices = IndicesOptions.fromOptions(false, true, true, false);
|
IndicesOptions allowNoIndices = IndicesOptions.fromOptions(false, true, true, false);
|
||||||
try {
|
try {
|
||||||
client().admin().cluster().prepareState().clear().setMetaData(true).setIndices("fzzbzz").setIndicesOptions(allowNoIndices).get();
|
client().admin().cluster().prepareState().clear().setMetaData(true)
|
||||||
|
.setIndices("fzzbzz").setIndicesOptions(allowNoIndices).get();
|
||||||
fail("Expected IndexNotFoundException");
|
fail("Expected IndexNotFoundException");
|
||||||
} catch (IndexNotFoundException e) {
|
} catch (IndexNotFoundException e) {
|
||||||
assertThat(e.getMessage(), is("no such index [fzzbzz]"));
|
assertThat(e.getMessage(), is("no such index [fzzbzz]"));
|
||||||
|
|
|
@ -232,7 +232,8 @@ public class AckIT extends ESIntegTestCase {
|
||||||
public void testIndicesAliasesNoAcknowledgement() {
|
public void testIndicesAliasesNoAcknowledgement() {
|
||||||
createIndex("test");
|
createIndex("test");
|
||||||
|
|
||||||
AcknowledgedResponse indicesAliasesResponse = client().admin().indices().prepareAliases().addAlias("test", "alias").setTimeout("0s").get();
|
AcknowledgedResponse indicesAliasesResponse = client().admin().indices().prepareAliases()
|
||||||
|
.addAlias("test", "alias").setTimeout("0s").get();
|
||||||
assertThat(indicesAliasesResponse.isAcknowledged(), equalTo(false));
|
assertThat(indicesAliasesResponse.isAcknowledged(), equalTo(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -285,7 +286,8 @@ public class AckIT extends ESIntegTestCase {
|
||||||
createIndex("test");
|
createIndex("test");
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
||||||
AcknowledgedResponse putMappingResponse = client().admin().indices().preparePutMapping("test").setType("test").setSource("field", "type=keyword").setTimeout("0s").get();
|
AcknowledgedResponse putMappingResponse = client().admin().indices().preparePutMapping("test").setType("test")
|
||||||
|
.setSource("field", "type=keyword").setTimeout("0s").get();
|
||||||
assertThat(putMappingResponse.isAcknowledged(), equalTo(false));
|
assertThat(putMappingResponse.isAcknowledged(), equalTo(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -94,19 +94,22 @@ public class DateMathExpressionResolverTests extends ESTestCase {
|
||||||
public void testExpression_CustomFormat() throws Exception {
|
public void testExpression_CustomFormat() throws Exception {
|
||||||
List<String> results = expressionResolver.resolve(context, Arrays.asList("<.marvel-{now/d{YYYY.MM.dd}}>"));
|
List<String> results = expressionResolver.resolve(context, Arrays.asList("<.marvel-{now/d{YYYY.MM.dd}}>"));
|
||||||
assertThat(results.size(), equalTo(1));
|
assertThat(results.size(), equalTo(1));
|
||||||
assertThat(results.get(0), equalTo(".marvel-" + DateTimeFormat.forPattern("YYYY.MM.dd").print(new DateTime(context.getStartTime(), UTC))));
|
assertThat(results.get(0),
|
||||||
|
equalTo(".marvel-" + DateTimeFormat.forPattern("YYYY.MM.dd").print(new DateTime(context.getStartTime(), UTC))));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExpression_EscapeStatic() throws Exception {
|
public void testExpression_EscapeStatic() throws Exception {
|
||||||
List<String> result = expressionResolver.resolve(context, Arrays.asList("<.mar\\{v\\}el-{now/d}>"));
|
List<String> result = expressionResolver.resolve(context, Arrays.asList("<.mar\\{v\\}el-{now/d}>"));
|
||||||
assertThat(result.size(), equalTo(1));
|
assertThat(result.size(), equalTo(1));
|
||||||
assertThat(result.get(0), equalTo(".mar{v}el-" + DateTimeFormat.forPattern("YYYY.MM.dd").print(new DateTime(context.getStartTime(), UTC))));
|
assertThat(result.get(0),
|
||||||
|
equalTo(".mar{v}el-" + DateTimeFormat.forPattern("YYYY.MM.dd").print(new DateTime(context.getStartTime(), UTC))));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExpression_EscapeDateFormat() throws Exception {
|
public void testExpression_EscapeDateFormat() throws Exception {
|
||||||
List<String> result = expressionResolver.resolve(context, Arrays.asList("<.marvel-{now/d{'\\{year\\}'YYYY}}>"));
|
List<String> result = expressionResolver.resolve(context, Arrays.asList("<.marvel-{now/d{'\\{year\\}'YYYY}}>"));
|
||||||
assertThat(result.size(), equalTo(1));
|
assertThat(result.size(), equalTo(1));
|
||||||
assertThat(result.get(0), equalTo(".marvel-" + DateTimeFormat.forPattern("'{year}'YYYY").print(new DateTime(context.getStartTime(), UTC))));
|
assertThat(result.get(0),
|
||||||
|
equalTo(".marvel-" + DateTimeFormat.forPattern("'{year}'YYYY").print(new DateTime(context.getStartTime(), UTC))));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExpression_MixedArray() throws Exception {
|
public void testExpression_MixedArray() throws Exception {
|
||||||
|
@ -115,9 +118,11 @@ public class DateMathExpressionResolverTests extends ESTestCase {
|
||||||
));
|
));
|
||||||
assertThat(result.size(), equalTo(4));
|
assertThat(result.size(), equalTo(4));
|
||||||
assertThat(result.get(0), equalTo("name1"));
|
assertThat(result.get(0), equalTo("name1"));
|
||||||
assertThat(result.get(1), equalTo(".marvel-" + DateTimeFormat.forPattern("YYYY.MM.dd").print(new DateTime(context.getStartTime(), UTC))));
|
assertThat(result.get(1),
|
||||||
|
equalTo(".marvel-" + DateTimeFormat.forPattern("YYYY.MM.dd").print(new DateTime(context.getStartTime(), UTC))));
|
||||||
assertThat(result.get(2), equalTo("name2"));
|
assertThat(result.get(2), equalTo("name2"));
|
||||||
assertThat(result.get(3), equalTo(".logstash-" + DateTimeFormat.forPattern("YYYY.MM").print(new DateTime(context.getStartTime(), UTC).withDayOfMonth(1))));
|
assertThat(result.get(3), equalTo(".logstash-" +
|
||||||
|
DateTimeFormat.forPattern("YYYY.MM").print(new DateTime(context.getStartTime(), UTC).withDayOfMonth(1))));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExpression_CustomTimeZoneInIndexName() throws Exception {
|
public void testExpression_CustomTimeZoneInIndexName() throws Exception {
|
||||||
|
@ -135,7 +140,8 @@ public class DateMathExpressionResolverTests extends ESTestCase {
|
||||||
DateTime now;
|
DateTime now;
|
||||||
if (hoursOffset >= 0) {
|
if (hoursOffset >= 0) {
|
||||||
// rounding to next day 00:00
|
// rounding to next day 00:00
|
||||||
now = DateTime.now(UTC).plusHours(hoursOffset).plusMinutes(minutesOffset).withHourOfDay(0).withMinuteOfHour(0).withSecondOfMinute(0);
|
now = DateTime.now(UTC).plusHours(hoursOffset).plusMinutes(minutesOffset)
|
||||||
|
.withHourOfDay(0).withMinuteOfHour(0).withSecondOfMinute(0);
|
||||||
} else {
|
} else {
|
||||||
// rounding to today 00:00
|
// rounding to today 00:00
|
||||||
now = DateTime.now(UTC).withHourOfDay(0).withMinuteOfHour(0).withSecondOfMinute(0);
|
now = DateTime.now(UTC).withHourOfDay(0).withMinuteOfHour(0).withSecondOfMinute(0);
|
||||||
|
|
|
@ -218,7 +218,8 @@ public class WildcardExpressionResolverTests extends ESTestCase {
|
||||||
// when ignoreAliases option is not set, WildcardExpressionResolver resolves the provided
|
// when ignoreAliases option is not set, WildcardExpressionResolver resolves the provided
|
||||||
// expressions against the defined indices and aliases
|
// expressions against the defined indices and aliases
|
||||||
IndicesOptions indicesAndAliasesOptions = IndicesOptions.fromOptions(false, false, true, false, true, false, false);
|
IndicesOptions indicesAndAliasesOptions = IndicesOptions.fromOptions(false, false, true, false, true, false, false);
|
||||||
IndexNameExpressionResolver.Context indicesAndAliasesContext = new IndexNameExpressionResolver.Context(state, indicesAndAliasesOptions);
|
IndexNameExpressionResolver.Context indicesAndAliasesContext =
|
||||||
|
new IndexNameExpressionResolver.Context(state, indicesAndAliasesOptions);
|
||||||
|
|
||||||
// ignoreAliases option is set, WildcardExpressionResolver resolves the provided expressions
|
// ignoreAliases option is set, WildcardExpressionResolver resolves the provided expressions
|
||||||
// only against the defined indices
|
// only against the defined indices
|
||||||
|
|
|
@ -141,7 +141,9 @@ public class UnassignedInfoTests extends ESAllocationTestCase {
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
.metaData(metaData)
|
.metaData(metaData)
|
||||||
.routingTable(RoutingTable.builder().addAsNewRestore(metaData.index("test"), new SnapshotRecoverySource(new Snapshot("rep1", new SnapshotId("snp1", UUIDs.randomBase64UUID())), Version.CURRENT, "test"), new IntHashSet()).build()).build();
|
.routingTable(RoutingTable.builder().addAsNewRestore(metaData.index("test"), new SnapshotRecoverySource(
|
||||||
|
new Snapshot("rep1", new SnapshotId("snp1", UUIDs.randomBase64UUID())), Version.CURRENT, "test"),
|
||||||
|
new IntHashSet()).build()).build();
|
||||||
for (ShardRouting shard : clusterState.getRoutingNodes().shardsWithState(UNASSIGNED)) {
|
for (ShardRouting shard : clusterState.getRoutingNodes().shardsWithState(UNASSIGNED)) {
|
||||||
assertThat(shard.unassignedInfo().getReason(), equalTo(UnassignedInfo.Reason.NEW_INDEX_RESTORED));
|
assertThat(shard.unassignedInfo().getReason(), equalTo(UnassignedInfo.Reason.NEW_INDEX_RESTORED));
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,7 +52,8 @@ public class AddIncrementallyTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
public void testAddNodesAndIndices() {
|
public void testAddNodesAndIndices() {
|
||||||
Settings.Builder settings = Settings.builder();
|
Settings.Builder settings = Settings.builder();
|
||||||
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(), ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
||||||
AllocationService service = createAllocationService(settings.build());
|
AllocationService service = createAllocationService(settings.build());
|
||||||
|
|
||||||
ClusterState clusterState = initCluster(service, 1, 3, 3, 1);
|
ClusterState clusterState = initCluster(service, 1, 3, 3, 1);
|
||||||
|
@ -95,7 +96,8 @@ public class AddIncrementallyTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
public void testMinimalRelocations() {
|
public void testMinimalRelocations() {
|
||||||
Settings.Builder settings = Settings.builder();
|
Settings.Builder settings = Settings.builder();
|
||||||
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(), ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString())
|
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString())
|
||||||
.put("cluster.routing.allocation.node_concurrent_recoveries", 2);
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 2);
|
||||||
AllocationService service = createAllocationService(settings.build());
|
AllocationService service = createAllocationService(settings.build());
|
||||||
|
|
||||||
|
@ -156,7 +158,8 @@ public class AddIncrementallyTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
public void testMinimalRelocationsNoLimit() {
|
public void testMinimalRelocationsNoLimit() {
|
||||||
Settings.Builder settings = Settings.builder();
|
Settings.Builder settings = Settings.builder();
|
||||||
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(), ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString())
|
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString())
|
||||||
.put("cluster.routing.allocation.node_concurrent_recoveries", 100)
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 100)
|
||||||
.put("cluster.routing.allocation.node_initial_primaries_recoveries", 100);
|
.put("cluster.routing.allocation.node_initial_primaries_recoveries", 100);
|
||||||
AllocationService service = createAllocationService(settings.build());
|
AllocationService service = createAllocationService(settings.build());
|
||||||
|
@ -261,8 +264,8 @@ public class AddIncrementallyTests extends ESAllocationTestCase {
|
||||||
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
||||||
|
|
||||||
for (int i = 0; i < numberOfIndices; i++) {
|
for (int i = 0; i < numberOfIndices; i++) {
|
||||||
IndexMetaData.Builder index = IndexMetaData.builder("test" + i).settings(settings(Version.CURRENT)).numberOfShards(numberOfShards).numberOfReplicas(
|
IndexMetaData.Builder index = IndexMetaData.builder("test" + i)
|
||||||
numberOfReplicas);
|
.settings(settings(Version.CURRENT)).numberOfShards(numberOfShards).numberOfReplicas(numberOfReplicas);
|
||||||
metaDataBuilder = metaDataBuilder.put(index);
|
metaDataBuilder = metaDataBuilder.put(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -279,7 +282,8 @@ public class AddIncrementallyTests extends ESAllocationTestCase {
|
||||||
for (int i = 0; i < numberOfNodes; i++) {
|
for (int i = 0; i < numberOfNodes; i++) {
|
||||||
nodes.add(newNode("node" + i));
|
nodes.add(newNode("node" + i));
|
||||||
}
|
}
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).nodes(nodes).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).nodes(nodes).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
clusterState = service.reroute(clusterState, "reroute");
|
clusterState = service.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("restart all the primary shards, replicas will start initializing");
|
logger.info("restart all the primary shards, replicas will start initializing");
|
||||||
|
@ -300,7 +304,8 @@ public class AddIncrementallyTests extends ESAllocationTestCase {
|
||||||
MetaData.Builder metaDataBuilder = MetaData.builder(clusterState.getMetaData());
|
MetaData.Builder metaDataBuilder = MetaData.builder(clusterState.getMetaData());
|
||||||
RoutingTable.Builder routingTableBuilder = RoutingTable.builder(clusterState.routingTable());
|
RoutingTable.Builder routingTableBuilder = RoutingTable.builder(clusterState.routingTable());
|
||||||
|
|
||||||
IndexMetaData.Builder index = IndexMetaData.builder("test" + indexOrdinal).settings(settings(Version.CURRENT)).numberOfShards(numberOfShards).numberOfReplicas(
|
IndexMetaData.Builder index = IndexMetaData.builder("test" + indexOrdinal).settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(numberOfShards).numberOfReplicas(
|
||||||
numberOfReplicas);
|
numberOfReplicas);
|
||||||
IndexMetaData imd = index.build();
|
IndexMetaData imd = index.build();
|
||||||
metaDataBuilder = metaDataBuilder.put(imd, true);
|
metaDataBuilder = metaDataBuilder.put(imd, true);
|
||||||
|
|
|
@ -73,7 +73,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(AllocationCommandsTests.class);
|
private final Logger logger = LogManager.getLogger(AllocationCommandsTests.class);
|
||||||
|
|
||||||
public void testMoveShardCommand() {
|
public void testMoveShardCommand() {
|
||||||
AllocationService allocation = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService allocation = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("creating an index with 1 shard, no replica");
|
logger.info("creating an index with 1 shard, no replica");
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -82,10 +83,12 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("adding two nodes and performing rerouting");
|
logger.info("adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = allocation.reroute(clusterState, "reroute");
|
clusterState = allocation.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("start primary shard");
|
logger.info("start primary shard");
|
||||||
|
@ -100,7 +103,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
toNodeId = "node1";
|
toNodeId = "node1";
|
||||||
}
|
}
|
||||||
ClusterState newState = allocation.reroute(clusterState,
|
ClusterState newState = allocation.reroute(clusterState,
|
||||||
new AllocationCommands(new MoveAllocationCommand("test", 0, existingNodeId, toNodeId)), false, false).getClusterState();
|
new AllocationCommands(new MoveAllocationCommand("test", 0, existingNodeId, toNodeId)),
|
||||||
|
false, false).getClusterState();
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
assertThat(clusterState.getRoutingNodes().node(existingNodeId).iterator().next().state(), equalTo(ShardRoutingState.RELOCATING));
|
assertThat(clusterState.getRoutingNodes().node(existingNodeId).iterator().next().state(), equalTo(ShardRoutingState.RELOCATING));
|
||||||
|
@ -131,14 +135,16 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
logger.info("--> building initial routing table");
|
logger.info("--> building initial routing table");
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder(index).settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(1)
|
.put(IndexMetaData.builder(index).settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(1)
|
||||||
.putInSyncAllocationIds(0, Collections.singleton("asdf")).putInSyncAllocationIds(1, Collections.singleton("qwertz")))
|
.putInSyncAllocationIds(0, Collections.singleton("asdf"))
|
||||||
|
.putInSyncAllocationIds(1, Collections.singleton("qwertz")))
|
||||||
.build();
|
.build();
|
||||||
// shard routing is added as "from recovery" instead of "new index creation" so that we can test below that allocating an empty
|
// shard routing is added as "from recovery" instead of "new index creation" so that we can test below that allocating an empty
|
||||||
// primary with accept_data_loss flag set to false fails
|
// primary with accept_data_loss flag set to false fails
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsRecovery(metaData.index(index))
|
.addAsRecovery(metaData.index(index))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
final ShardId shardId = new ShardId(metaData.index(index).getIndex(), 0);
|
final ShardId shardId = new ShardId(metaData.index(index).getIndex(), 0);
|
||||||
|
|
||||||
logger.info("--> adding 3 nodes on same rack and do rerouting");
|
logger.info("--> adding 3 nodes on same rack and do rerouting");
|
||||||
|
@ -185,23 +191,28 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("--> allocating empty primary with acceptDataLoss flag set to false");
|
logger.info("--> allocating empty primary with acceptDataLoss flag set to false");
|
||||||
try {
|
try {
|
||||||
allocation.reroute(clusterState, new AllocationCommands(new AllocateEmptyPrimaryAllocationCommand("test", 0, "node1", false)), false, false);
|
allocation.reroute(clusterState, new AllocationCommands(
|
||||||
|
new AllocateEmptyPrimaryAllocationCommand("test", 0, "node1", false)), false, false);
|
||||||
fail("expected IllegalArgumentException when allocating empty primary with acceptDataLoss flag set to false");
|
fail("expected IllegalArgumentException when allocating empty primary with acceptDataLoss flag set to false");
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
assertThat(e.getMessage(), containsString("allocating an empty primary for " + shardId + " can result in data loss. Please confirm by setting the accept_data_loss parameter to true"));
|
assertThat(e.getMessage(), containsString("allocating an empty primary for " + shardId +
|
||||||
|
" can result in data loss. Please confirm by setting the accept_data_loss parameter to true"));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("--> allocating stale primary with acceptDataLoss flag set to false");
|
logger.info("--> allocating stale primary with acceptDataLoss flag set to false");
|
||||||
try {
|
try {
|
||||||
allocation.reroute(clusterState, new AllocationCommands(new AllocateStalePrimaryAllocationCommand(index, shardId.id(), "node1", false)), false, false);
|
allocation.reroute(clusterState, new AllocationCommands(
|
||||||
|
new AllocateStalePrimaryAllocationCommand(index, shardId.id(), "node1", false)), false, false);
|
||||||
fail("expected IllegalArgumentException when allocating stale primary with acceptDataLoss flag set to false");
|
fail("expected IllegalArgumentException when allocating stale primary with acceptDataLoss flag set to false");
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
assertThat(e.getMessage(), containsString("allocating an empty primary for " + shardId + " can result in data loss. Please confirm by setting the accept_data_loss parameter to true"));
|
assertThat(e.getMessage(), containsString("allocating an empty primary for " + shardId +
|
||||||
|
" can result in data loss. Please confirm by setting the accept_data_loss parameter to true"));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("--> allocating empty primary with acceptDataLoss flag set to true");
|
logger.info("--> allocating empty primary with acceptDataLoss flag set to true");
|
||||||
ClusterState newState = allocation.reroute(clusterState,
|
ClusterState newState = allocation.reroute(clusterState,
|
||||||
new AllocationCommands(new AllocateEmptyPrimaryAllocationCommand("test", 0, "node1", true)), false, false).getClusterState();
|
new AllocationCommands(new AllocateEmptyPrimaryAllocationCommand("test", 0, "node1", true)),
|
||||||
|
false, false).getClusterState();
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
assertThat(clusterState.getRoutingNodes().node("node1").size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().node("node1").size(), equalTo(1));
|
||||||
|
@ -216,7 +227,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("--> allocate the replica shard on the primary shard node, should fail");
|
logger.info("--> allocate the replica shard on the primary shard node, should fail");
|
||||||
try {
|
try {
|
||||||
allocation.reroute(clusterState, new AllocationCommands(new AllocateReplicaAllocationCommand("test", 0, "node1")), false, false);
|
allocation.reroute(clusterState, new AllocationCommands(
|
||||||
|
new AllocateReplicaAllocationCommand("test", 0, "node1")), false, false);
|
||||||
fail("expected IllegalArgumentException when allocating replica shard on the primary shard node");
|
fail("expected IllegalArgumentException when allocating replica shard on the primary shard node");
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
}
|
}
|
||||||
|
@ -260,7 +272,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding 3 nodes");
|
logger.info("--> adding 3 nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -483,14 +496,16 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
public void testXContent() throws Exception {
|
public void testXContent() throws Exception {
|
||||||
String commands = "{\n" +
|
String commands = "{\n" +
|
||||||
" \"commands\" : [\n" +
|
" \"commands\" : [\n" +
|
||||||
" {\"allocate_empty_primary\" : {\"index\" : \"test\", \"shard\" : 1, \"node\" : \"node1\", \"accept_data_loss\" : true}}\n" +
|
" {\"allocate_empty_primary\" : {\"index\" : \"test\", \"shard\" : 1," +
|
||||||
" ,{\"allocate_stale_primary\" : {\"index\" : \"test\", \"shard\" : 2, \"node\" : \"node1\", \"accept_data_loss\" : true}}\n" +
|
" \"node\" : \"node1\", \"accept_data_loss\" : true}}\n" +
|
||||||
" ,{\"allocate_replica\" : {\"index\" : \"test\", \"shard\" : 2, \"node\" : \"node1\"}}\n" +
|
" ,{\"allocate_stale_primary\" : {\"index\" : \"test\", \"shard\" : 2," +
|
||||||
" ,{\"move\" : {\"index\" : \"test\", \"shard\" : 3, \"from_node\" : \"node2\", \"to_node\" : \"node3\"}} \n" +
|
" \"node\" : \"node1\", \"accept_data_loss\" : true}}\n" +
|
||||||
" ,{\"cancel\" : {\"index\" : \"test\", \"shard\" : 4, \"node\" : \"node5\", \"allow_primary\" : true}} \n" +
|
" ,{\"allocate_replica\" : {\"index\" : \"test\", \"shard\" : 2, \"node\" : \"node1\"}}\n" +
|
||||||
" ]\n" +
|
" ,{\"move\" : {\"index\" : \"test\", \"shard\" : 3, \"from_node\" : \"node2\", \"to_node\" : \"node3\"}} \n" +
|
||||||
"}\n";
|
" ,{\"cancel\" : {\"index\" : \"test\", \"shard\" : 4, \"node\" : \"node5\", \"allow_primary\" : true}} \n" +
|
||||||
|
" ]\n" +
|
||||||
|
"}\n";
|
||||||
XContentParser parser = createParser(JsonXContent.jsonXContent, commands);
|
XContentParser parser = createParser(JsonXContent.jsonXContent, commands);
|
||||||
// move two tokens, parser expected to be "on" `commands` field
|
// move two tokens, parser expected to be "on" `commands` field
|
||||||
parser.nextToken();
|
parser.nextToken();
|
||||||
|
@ -529,7 +544,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testMoveShardToNonDataNode() {
|
public void testMoveShardToNonDataNode() {
|
||||||
AllocationService allocation = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService allocation = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("creating an index with 1 shard, no replica");
|
logger.info("creating an index with 1 shard, no replica");
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -538,7 +554,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes");
|
logger.info("--> adding two nodes");
|
||||||
|
|
||||||
|
@ -561,11 +578,13 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
new RoutingNodes(clusterState, false), clusterState, ClusterInfo.EMPTY, System.nanoTime());
|
new RoutingNodes(clusterState, false), clusterState, ClusterInfo.EMPTY, System.nanoTime());
|
||||||
logger.info("--> executing move allocation command to non-data node");
|
logger.info("--> executing move allocation command to non-data node");
|
||||||
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, () -> command.execute(routingAllocation, false));
|
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, () -> command.execute(routingAllocation, false));
|
||||||
assertEquals("[move_allocation] can't move [test][0] from " + node1 + " to " + node2 + ": source [" + node2.getName() + "] is not a data node.", e.getMessage());
|
assertEquals("[move_allocation] can't move [test][0] from " + node1 + " to " +
|
||||||
|
node2 + ": source [" + node2.getName() + "] is not a data node.", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testMoveShardFromNonDataNode() {
|
public void testMoveShardFromNonDataNode() {
|
||||||
AllocationService allocation = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService allocation = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("creating an index with 1 shard, no replica");
|
logger.info("creating an index with 1 shard, no replica");
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -574,7 +593,8 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes");
|
logger.info("--> adding two nodes");
|
||||||
|
|
||||||
|
@ -596,6 +616,7 @@ public class AllocationCommandsTests extends ESAllocationTestCase {
|
||||||
new RoutingNodes(clusterState, false), clusterState, ClusterInfo.EMPTY, System.nanoTime());
|
new RoutingNodes(clusterState, false), clusterState, ClusterInfo.EMPTY, System.nanoTime());
|
||||||
logger.info("--> executing move allocation command from non-data node");
|
logger.info("--> executing move allocation command from non-data node");
|
||||||
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, () -> command.execute(routingAllocation, false));
|
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, () -> command.execute(routingAllocation, false));
|
||||||
assertEquals("[move_allocation] can't move [test][0] from " + node2 + " to " + node1 + ": source [" + node2.getName() + "] is not a data node.", e.getMessage());
|
assertEquals("[move_allocation] can't move [test][0] from " + node2 + " to " + node1 +
|
||||||
|
": source [" + node2.getName() + "] is not a data node.", e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,8 @@ public class AllocationPriorityTests extends ESAllocationTestCase {
|
||||||
put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_RECOVERIES_SETTING.getKey(), 1)
|
put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_RECOVERIES_SETTING.getKey(), 1)
|
||||||
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_OUTGOING_RECOVERIES_SETTING.getKey(), 10)
|
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_OUTGOING_RECOVERIES_SETTING.getKey(), 10)
|
||||||
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_INITIAL_PRIMARIES_RECOVERIES_SETTING.getKey(), 1)
|
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_INITIAL_PRIMARIES_RECOVERIES_SETTING.getKey(), 1)
|
||||||
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_INCOMING_RECOVERIES_SETTING.getKey(), 1).build());
|
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_INCOMING_RECOVERIES_SETTING.getKey(), 1)
|
||||||
|
.build());
|
||||||
final String highPriorityName;
|
final String highPriorityName;
|
||||||
final String lowPriorityName;
|
final String lowPriorityName;
|
||||||
final int priorityFirst;
|
final int priorityFirst;
|
||||||
|
@ -58,16 +59,20 @@ public class AllocationPriorityTests extends ESAllocationTestCase {
|
||||||
priorityFirst = 1;
|
priorityFirst = 1;
|
||||||
}
|
}
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("first").settings(settings(Version.CURRENT).put(IndexMetaData.SETTING_PRIORITY, priorityFirst)).numberOfShards(2).numberOfReplicas(1))
|
.put(IndexMetaData.builder("first").settings(settings(Version.CURRENT)
|
||||||
.put(IndexMetaData.builder("second").settings(settings(Version.CURRENT).put(IndexMetaData.SETTING_PRIORITY, prioritySecond)).numberOfShards(2).numberOfReplicas(1))
|
.put(IndexMetaData.SETTING_PRIORITY, priorityFirst)).numberOfShards(2).numberOfReplicas(1))
|
||||||
|
.put(IndexMetaData.builder("second").settings(settings(Version.CURRENT)
|
||||||
|
.put(IndexMetaData.SETTING_PRIORITY, prioritySecond)).numberOfShards(2).numberOfReplicas(1))
|
||||||
.build();
|
.build();
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder()
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("first"))
|
.addAsNew(metaData.index("first"))
|
||||||
.addAsNew(metaData.index("second"))
|
.addAsNew(metaData.index("second"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))
|
||||||
|
.add(newNode("node2"))).build();
|
||||||
clusterState = allocation.reroute(clusterState, "reroute");
|
clusterState = allocation.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
clusterState = allocation.reroute(clusterState, "reroute");
|
clusterState = allocation.reroute(clusterState, "reroute");
|
||||||
|
@ -81,7 +86,8 @@ public class AllocationPriorityTests extends ESAllocationTestCase {
|
||||||
assertEquals(lowPriorityName, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(1).getIndexName());
|
assertEquals(lowPriorityName, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(1).getIndexName());
|
||||||
|
|
||||||
clusterState = allocation.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = allocation.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
assertEquals(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).toString(),2, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size());
|
assertEquals(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).toString(),2,
|
||||||
|
clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size());
|
||||||
assertEquals(highPriorityName, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(0).getIndexName());
|
assertEquals(highPriorityName, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(0).getIndexName());
|
||||||
assertEquals(highPriorityName, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(1).getIndexName());
|
assertEquals(highPriorityName, clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(1).getIndexName());
|
||||||
|
|
||||||
|
|
|
@ -68,7 +68,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -94,7 +95,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node3"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -128,7 +130,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -155,7 +158,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node4"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node4"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -196,7 +200,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -229,7 +234,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(5));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(5));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(5));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(5));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(5));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(5));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node3"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
logger.info("--> complete initializing");
|
logger.info("--> complete initializing");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -279,7 +285,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -306,7 +313,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(10));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(10));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(10));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(10));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(10));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(10));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node3"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
logger.info("--> complete initializing");
|
logger.info("--> complete initializing");
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
|
@ -362,7 +370,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -388,7 +397,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(2));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(), equalTo("node3"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -405,7 +415,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(2));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node4"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node4"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -433,7 +444,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -461,7 +473,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(3));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(3));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node5"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node5"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -478,7 +491,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(3));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(3));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(), equalTo("node6"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.RELOCATING).get(0).relocatingNodeId(),
|
||||||
|
equalTo("node6"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -507,7 +521,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -532,7 +547,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(), equalTo("node3"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -569,7 +585,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -595,7 +612,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(), equalTo("node4"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(),
|
||||||
|
equalTo("node4"));
|
||||||
|
|
||||||
logger.info("--> complete relocation");
|
logger.info("--> complete relocation");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -639,7 +657,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes on same rack and do rerouting");
|
logger.info("--> adding two nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -662,7 +681,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(10));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(10));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(10));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(10));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(), equalTo("node3"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
logger.info("--> complete initializing");
|
logger.info("--> complete initializing");
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -711,7 +731,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes in different zones and do rerouting");
|
logger.info("--> adding two nodes in different zones and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -739,7 +760,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(8));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.STARTED).size(), equalTo(8));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(2));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(), equalTo("A-1"));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(),
|
||||||
|
equalTo("A-1"));
|
||||||
logger.info("--> starting initializing shards on the new node");
|
logger.info("--> starting initializing shards on the new node");
|
||||||
|
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
@ -767,7 +789,8 @@ public class AwarenessAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding 5 nodes in different zones and do rerouting");
|
logger.info("--> adding 5 nodes in different zones and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
|
|
@ -67,7 +67,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
final float balanceTreshold = 1.0f;
|
final float balanceTreshold = 1.0f;
|
||||||
|
|
||||||
Settings.Builder settings = Settings.builder();
|
Settings.Builder settings = Settings.builder();
|
||||||
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(), ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
||||||
settings.put(BalancedShardsAllocator.INDEX_BALANCE_FACTOR_SETTING.getKey(), indexBalance);
|
settings.put(BalancedShardsAllocator.INDEX_BALANCE_FACTOR_SETTING.getKey(), indexBalance);
|
||||||
settings.put(BalancedShardsAllocator.SHARD_BALANCE_FACTOR_SETTING.getKey(), replicaBalance);
|
settings.put(BalancedShardsAllocator.SHARD_BALANCE_FACTOR_SETTING.getKey(), replicaBalance);
|
||||||
settings.put(BalancedShardsAllocator.THRESHOLD_SETTING.getKey(), balanceTreshold);
|
settings.put(BalancedShardsAllocator.THRESHOLD_SETTING.getKey(), balanceTreshold);
|
||||||
|
@ -75,13 +76,16 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
AllocationService strategy = createAllocationService(settings.build(), new NoopGatewayAllocator());
|
AllocationService strategy = createAllocationService(settings.build(), new NoopGatewayAllocator());
|
||||||
|
|
||||||
ClusterState clusterState = initCluster(strategy);
|
ClusterState clusterState = initCluster(strategy);
|
||||||
assertIndexBalance(clusterState.getRoutingTable(), clusterState.getRoutingNodes(), numberOfNodes, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
assertIndexBalance(clusterState.getRoutingTable(), clusterState.getRoutingNodes(), numberOfNodes, numberOfIndices,
|
||||||
|
numberOfReplicas, numberOfShards, balanceTreshold);
|
||||||
|
|
||||||
clusterState = addNode(clusterState, strategy);
|
clusterState = addNode(clusterState, strategy);
|
||||||
assertIndexBalance(clusterState.getRoutingTable(), clusterState.getRoutingNodes(), numberOfNodes + 1, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
assertIndexBalance(clusterState.getRoutingTable(), clusterState.getRoutingNodes(), numberOfNodes + 1,
|
||||||
|
numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
||||||
|
|
||||||
clusterState = removeNodes(clusterState, strategy);
|
clusterState = removeNodes(clusterState, strategy);
|
||||||
assertIndexBalance(clusterState.getRoutingTable(), clusterState.getRoutingNodes(), (numberOfNodes + 1) - (numberOfNodes + 1) / 2, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
assertIndexBalance(clusterState.getRoutingTable(), clusterState.getRoutingNodes(),
|
||||||
|
(numberOfNodes + 1) - (numberOfNodes + 1) / 2, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testReplicaBalance() {
|
public void testReplicaBalance() {
|
||||||
|
@ -91,7 +95,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
final float balanceTreshold = 1.0f;
|
final float balanceTreshold = 1.0f;
|
||||||
|
|
||||||
Settings.Builder settings = Settings.builder();
|
Settings.Builder settings = Settings.builder();
|
||||||
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(), ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
||||||
settings.put(BalancedShardsAllocator.INDEX_BALANCE_FACTOR_SETTING.getKey(), indexBalance);
|
settings.put(BalancedShardsAllocator.INDEX_BALANCE_FACTOR_SETTING.getKey(), indexBalance);
|
||||||
settings.put(BalancedShardsAllocator.SHARD_BALANCE_FACTOR_SETTING.getKey(), replicaBalance);
|
settings.put(BalancedShardsAllocator.SHARD_BALANCE_FACTOR_SETTING.getKey(), replicaBalance);
|
||||||
settings.put(BalancedShardsAllocator.THRESHOLD_SETTING.getKey(), balanceTreshold);
|
settings.put(BalancedShardsAllocator.THRESHOLD_SETTING.getKey(), balanceTreshold);
|
||||||
|
@ -99,13 +104,16 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
AllocationService strategy = createAllocationService(settings.build(), new NoopGatewayAllocator());
|
AllocationService strategy = createAllocationService(settings.build(), new NoopGatewayAllocator());
|
||||||
|
|
||||||
ClusterState clusterState = initCluster(strategy);
|
ClusterState clusterState = initCluster(strategy);
|
||||||
assertReplicaBalance(logger, clusterState.getRoutingNodes(), numberOfNodes, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
assertReplicaBalance(logger, clusterState.getRoutingNodes(), numberOfNodes, numberOfIndices,
|
||||||
|
numberOfReplicas, numberOfShards, balanceTreshold);
|
||||||
|
|
||||||
clusterState = addNode(clusterState, strategy);
|
clusterState = addNode(clusterState, strategy);
|
||||||
assertReplicaBalance(logger, clusterState.getRoutingNodes(), numberOfNodes + 1, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
assertReplicaBalance(logger, clusterState.getRoutingNodes(), numberOfNodes + 1,
|
||||||
|
numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
||||||
|
|
||||||
clusterState = removeNodes(clusterState, strategy);
|
clusterState = removeNodes(clusterState, strategy);
|
||||||
assertReplicaBalance(logger, clusterState.getRoutingNodes(), (numberOfNodes + 1) - (numberOfNodes + 1) / 2, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
assertReplicaBalance(logger, clusterState.getRoutingNodes(),
|
||||||
|
(numberOfNodes + 1) - (numberOfNodes + 1) / 2, numberOfIndices, numberOfReplicas, numberOfShards, balanceTreshold);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,7 +122,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
||||||
|
|
||||||
for (int i = 0; i < numberOfIndices; i++) {
|
for (int i = 0; i < numberOfIndices; i++) {
|
||||||
IndexMetaData.Builder index = IndexMetaData.builder("test" + i).settings(settings(Version.CURRENT)).numberOfShards(numberOfShards).numberOfReplicas(numberOfReplicas);
|
IndexMetaData.Builder index = IndexMetaData.builder("test" + i).settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(numberOfShards).numberOfReplicas(numberOfReplicas);
|
||||||
metaDataBuilder = metaDataBuilder.put(index);
|
metaDataBuilder = metaDataBuilder.put(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,7 +141,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
for (int i = 0; i < numberOfNodes; i++) {
|
for (int i = 0; i < numberOfNodes; i++) {
|
||||||
nodes.add(newNode("node" + i));
|
nodes.add(newNode("node" + i));
|
||||||
}
|
}
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).nodes(nodes).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).nodes(nodes).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("restart all the primary shards, replicas will start initializing");
|
logger.info("restart all the primary shards, replicas will start initializing");
|
||||||
|
@ -191,20 +201,21 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void assertReplicaBalance(Logger logger, RoutingNodes nodes, int numberOfNodes, int numberOfIndices, int numberOfReplicas, int numberOfShards, float treshold) {
|
private void assertReplicaBalance(Logger logger, RoutingNodes nodes, int numberOfNodes, int numberOfIndices, int numberOfReplicas,
|
||||||
|
int numberOfShards, float treshold) {
|
||||||
final int numShards = numberOfIndices * numberOfShards * (numberOfReplicas + 1);
|
final int numShards = numberOfIndices * numberOfShards * (numberOfReplicas + 1);
|
||||||
final float avgNumShards = (float) (numShards) / (float) (numberOfNodes);
|
final float avgNumShards = (float) (numShards) / (float) (numberOfNodes);
|
||||||
final int minAvgNumberOfShards = Math.round(Math.round(Math.floor(avgNumShards - treshold)));
|
final int minAvgNumberOfShards = Math.round(Math.round(Math.floor(avgNumShards - treshold)));
|
||||||
final int maxAvgNumberOfShards = Math.round(Math.round(Math.ceil(avgNumShards + treshold)));
|
final int maxAvgNumberOfShards = Math.round(Math.round(Math.ceil(avgNumShards + treshold)));
|
||||||
|
|
||||||
for (RoutingNode node : nodes) {
|
for (RoutingNode node : nodes) {
|
||||||
// logger.info(node.nodeId() + ": " + node.shardsWithState(INITIALIZING, STARTED).size() + " shards ("+minAvgNumberOfShards+" to "+maxAvgNumberOfShards+")");
|
|
||||||
assertThat(node.shardsWithState(STARTED).size(), Matchers.greaterThanOrEqualTo(minAvgNumberOfShards));
|
assertThat(node.shardsWithState(STARTED).size(), Matchers.greaterThanOrEqualTo(minAvgNumberOfShards));
|
||||||
assertThat(node.shardsWithState(STARTED).size(), Matchers.lessThanOrEqualTo(maxAvgNumberOfShards));
|
assertThat(node.shardsWithState(STARTED).size(), Matchers.lessThanOrEqualTo(maxAvgNumberOfShards));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertIndexBalance(RoutingTable routingTable, RoutingNodes nodes, int numberOfNodes, int numberOfIndices, int numberOfReplicas, int numberOfShards, float treshold) {
|
private void assertIndexBalance(RoutingTable routingTable, RoutingNodes nodes, int numberOfNodes, int numberOfIndices,
|
||||||
|
int numberOfReplicas, int numberOfShards, float treshold) {
|
||||||
|
|
||||||
final int numShards = numberOfShards * (numberOfReplicas + 1);
|
final int numShards = numberOfShards * (numberOfReplicas + 1);
|
||||||
final float avgNumShards = (float) (numShards) / (float) (numberOfNodes);
|
final float avgNumShards = (float) (numShards) / (float) (numberOfNodes);
|
||||||
|
@ -213,7 +224,6 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
for (ObjectCursor<String> index : routingTable.indicesRouting().keys()) {
|
for (ObjectCursor<String> index : routingTable.indicesRouting().keys()) {
|
||||||
for (RoutingNode node : nodes) {
|
for (RoutingNode node : nodes) {
|
||||||
// logger.info(node.nodeId() +":"+index+ ": " + node.shardsWithState(index, INITIALIZING, STARTED).size() + " shards ("+minAvgNumberOfShards+" to "+maxAvgNumberOfShards+")");
|
|
||||||
assertThat(node.shardsWithState(index.value, STARTED).size(), Matchers.greaterThanOrEqualTo(minAvgNumberOfShards));
|
assertThat(node.shardsWithState(index.value, STARTED).size(), Matchers.greaterThanOrEqualTo(minAvgNumberOfShards));
|
||||||
assertThat(node.shardsWithState(index.value, STARTED).size(), Matchers.lessThanOrEqualTo(maxAvgNumberOfShards));
|
assertThat(node.shardsWithState(index.value, STARTED).size(), Matchers.lessThanOrEqualTo(maxAvgNumberOfShards));
|
||||||
}
|
}
|
||||||
|
@ -235,7 +245,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
settings.put(BalancedShardsAllocator.INDEX_BALANCE_FACTOR_SETTING.getKey(), 0.2);
|
settings.put(BalancedShardsAllocator.INDEX_BALANCE_FACTOR_SETTING.getKey(), 0.2);
|
||||||
settings.put(BalancedShardsAllocator.SHARD_BALANCE_FACTOR_SETTING.getKey(), 0.3);
|
settings.put(BalancedShardsAllocator.SHARD_BALANCE_FACTOR_SETTING.getKey(), 0.3);
|
||||||
settings.put(BalancedShardsAllocator.THRESHOLD_SETTING.getKey(), 2.0);
|
settings.put(BalancedShardsAllocator.THRESHOLD_SETTING.getKey(), 2.0);
|
||||||
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(), ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
settings.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString());
|
||||||
service.applySettings(settings.build());
|
service.applySettings(settings.build());
|
||||||
assertThat(allocator.getIndexBalance(), Matchers.equalTo(0.2f));
|
assertThat(allocator.getIndexBalance(), Matchers.equalTo(0.2f));
|
||||||
assertThat(allocator.getShardBalance(), Matchers.equalTo(0.3f));
|
assertThat(allocator.getShardBalance(), Matchers.equalTo(0.3f));
|
||||||
|
@ -330,7 +341,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
}, EmptyClusterInfoService.INSTANCE);
|
}, EmptyClusterInfoService.INSTANCE);
|
||||||
MetaData.Builder metaDataBuilder = MetaData.builder();
|
MetaData.Builder metaDataBuilder = MetaData.builder();
|
||||||
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
||||||
IndexMetaData.Builder indexMeta = IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(5).numberOfReplicas(1);
|
IndexMetaData.Builder indexMeta = IndexMetaData.builder("test")
|
||||||
|
.settings(settings(Version.CURRENT)).numberOfShards(5).numberOfReplicas(1);
|
||||||
metaDataBuilder = metaDataBuilder.put(indexMeta);
|
metaDataBuilder = metaDataBuilder.put(indexMeta);
|
||||||
MetaData metaData = metaDataBuilder.build();
|
MetaData metaData = metaDataBuilder.build();
|
||||||
for (ObjectCursor<IndexMetaData> cursor : metaData.indices().values()) {
|
for (ObjectCursor<IndexMetaData> cursor : metaData.indices().values()) {
|
||||||
|
@ -343,7 +355,8 @@ public class BalanceConfigurationTests extends ESAllocationTestCase {
|
||||||
nodes.add(node);
|
nodes.add(node);
|
||||||
}
|
}
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).nodes(nodes).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).nodes(nodes).metaData(metaData).routingTable(routingTable).build();
|
||||||
routingTable = strategy.reroute(clusterState, "reroute").routingTable();
|
routingTable = strategy.reroute(clusterState, "reroute").routingTable();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
||||||
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
||||||
|
|
|
@ -49,7 +49,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(ClusterRebalanceRoutingTests.class);
|
private final Logger logger = LogManager.getLogger(ClusterRebalanceRoutingTests.class);
|
||||||
|
|
||||||
public void testAlways() {
|
public void testAlways() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -62,10 +63,12 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
||||||
|
@ -126,7 +129,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
|
|
||||||
public void testClusterPrimariesActive1() {
|
public void testClusterPrimariesActive1() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider
|
||||||
|
.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_PRIMARIES_ACTIVE.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_PRIMARIES_ACTIVE.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -139,10 +143,12 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
||||||
assertThat(clusterState.routingTable().index("test1").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test1").shard(i).size(), equalTo(2));
|
||||||
|
@ -219,7 +225,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testClusterPrimariesActive2() {
|
public void testClusterPrimariesActive2() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider
|
||||||
|
.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_PRIMARIES_ACTIVE.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_PRIMARIES_ACTIVE.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -232,10 +239,12 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
||||||
|
@ -295,7 +304,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testClusterAllActive1() {
|
public void testClusterAllActive1() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_ALL_ACTIVE.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_ALL_ACTIVE.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -308,10 +318,12 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
||||||
|
@ -402,11 +414,13 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
|
|
||||||
assertThat(routingNodes.node("node3").size(), equalTo(1));
|
assertThat(routingNodes.node("node3").size(), equalTo(1));
|
||||||
assertThat(routingNodes.node("node3").iterator().next().shardId().getIndex().getName(), anyOf(equalTo("test1"), equalTo("test2")));
|
assertThat(routingNodes.node("node3").iterator().next().shardId().getIndex().getName(), anyOf(equalTo("test1"),
|
||||||
|
equalTo("test2")));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testClusterAllActive2() {
|
public void testClusterAllActive2() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_ALL_ACTIVE.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_ALL_ACTIVE.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -419,10 +433,12 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
||||||
|
@ -482,7 +498,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testClusterAllActive3() {
|
public void testClusterAllActive3() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider
|
||||||
|
.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_ALL_ACTIVE.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.INDICES_ALL_ACTIVE.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -495,10 +512,12 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test1").shards().size(); i++) {
|
||||||
|
@ -605,7 +624,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test1"))
|
.addAsNew(metaData.index("test1"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
|
@ -650,7 +670,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test1").shard(i).primaryShard().state(), equalTo(INITIALIZING));
|
assertThat(clusterState.routingTable().index("test1").shard(i).primaryShard().state(), equalTo(INITIALIZING));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.debug("now start initializing shards and expect exactly one rebalance from node1 to node 2 since index [test] is all on node1");
|
logger.debug("now start initializing shards and expect exactly one rebalance" +
|
||||||
|
" from node1 to node 2 since index [test] is all on node1");
|
||||||
|
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
clusterState = strategy.applyStartedShards(clusterState, routingNodes.shardsWithState("test1", INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, routingNodes.shardsWithState("test1", INITIALIZING));
|
||||||
|
@ -676,7 +697,8 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
public void testRebalanceWhileShardFetching() {
|
public void testRebalanceWhileShardFetching() {
|
||||||
final AtomicBoolean hasFetches = new AtomicBoolean(true);
|
final AtomicBoolean hasFetches = new AtomicBoolean(true);
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build(), new TestGatewayAllocator() {
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build(), new TestGatewayAllocator() {
|
||||||
@Override
|
@Override
|
||||||
public void allocateUnassigned(RoutingAllocation allocation) {
|
public void allocateUnassigned(RoutingAllocation allocation) {
|
||||||
|
@ -689,16 +711,20 @@ public class ClusterRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(2).numberOfReplicas(0))
|
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(2).numberOfReplicas(0))
|
||||||
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT).put(IndexMetaData.INDEX_ROUTING_EXCLUDE_GROUP_SETTING.getKey() + "_id", "node1,node2")).numberOfShards(2).numberOfReplicas(0))
|
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)
|
||||||
|
.put(IndexMetaData.INDEX_ROUTING_EXCLUDE_GROUP_SETTING.getKey() + "_id", "node1,node2"))
|
||||||
|
.numberOfShards(2).numberOfReplicas(0))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
// we use a second index here (test1) that never gets assigned otherwise allocateUnassigned is never called if we don't have unassigned shards.
|
// we use a second index here (test1) that never gets assigned otherwise allocateUnassigned
|
||||||
|
// is never called if we don't have unassigned shards.
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder()
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.addAsNew(metaData.index("test1"))
|
.addAsNew(metaData.index("test1"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
|
|
|
@ -57,7 +57,8 @@ public class ConcurrentRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -69,7 +70,8 @@ public class ConcurrentRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("start two nodes and fully start the shards");
|
logger.info("start two nodes and fully start the shards");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -90,7 +92,9 @@ public class ConcurrentRebalanceRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("now, start 8 more nodes, and check that no rebalancing/relocation have happened");
|
logger.info("now, start 8 more nodes, and check that no rebalancing/relocation have happened");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
.add(newNode("node3")).add(newNode("node4")).add(newNode("node5")).add(newNode("node6")).add(newNode("node7")).add(newNode("node8")).add(newNode("node9")).add(newNode("node10")))
|
.add(newNode("node3")).add(newNode("node4")).add(newNode("node5"))
|
||||||
|
.add(newNode("node6")).add(newNode("node7")).add(newNode("node8"))
|
||||||
|
.add(newNode("node9")).add(newNode("node10")))
|
||||||
.build();
|
.build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,8 @@ public class DeadNodesAllocationTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -102,7 +103,8 @@ public class DeadNodesAllocationTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -140,8 +142,8 @@ public class DeadNodesAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("--> moving primary shard to node3");
|
logger.info("--> moving primary shard to node3");
|
||||||
AllocationService.CommandsResult commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
AllocationService.CommandsResult commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
||||||
new MoveAllocationCommand("test", 0, clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), "node3")),
|
new MoveAllocationCommand("test", 0, clusterState.routingTable().index("test")
|
||||||
false, false);
|
.shard(0).primaryShard().currentNodeId(), "node3")), false, false);
|
||||||
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
||||||
clusterState = commandsResult.getClusterState();
|
clusterState = commandsResult.getClusterState();
|
||||||
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(RELOCATING));
|
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(RELOCATING));
|
||||||
|
@ -171,7 +173,8 @@ public class DeadNodesAllocationTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -209,8 +212,8 @@ public class DeadNodesAllocationTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("--> moving primary shard to node3");
|
logger.info("--> moving primary shard to node3");
|
||||||
AllocationService.CommandsResult commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
AllocationService.CommandsResult commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
||||||
new MoveAllocationCommand("test",0 , clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), "node3")),
|
new MoveAllocationCommand("test",0 , clusterState.routingTable().index("test")
|
||||||
false, false);
|
.shard(0).primaryShard().currentNodeId(), "node3")), false, false);
|
||||||
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
||||||
clusterState = commandsResult.getClusterState();
|
clusterState = commandsResult.getClusterState();
|
||||||
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(RELOCATING));
|
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(RELOCATING));
|
||||||
|
|
|
@ -41,7 +41,8 @@ public class ElectReplicaAsPrimaryDuringRelocationTests extends ESAllocationTest
|
||||||
private final Logger logger = LogManager.getLogger(ElectReplicaAsPrimaryDuringRelocationTests.class);
|
private final Logger logger = LogManager.getLogger(ElectReplicaAsPrimaryDuringRelocationTests.class);
|
||||||
|
|
||||||
public void testElectReplicaAsPrimaryDuringRelocation() {
|
public void testElectReplicaAsPrimaryDuringRelocation() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -53,10 +54,12 @@ public class ElectReplicaAsPrimaryDuringRelocationTests extends ESAllocationTest
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))
|
||||||
|
.add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("Start the primary shards");
|
logger.info("Start the primary shards");
|
||||||
|
@ -75,7 +78,8 @@ public class ElectReplicaAsPrimaryDuringRelocationTests extends ESAllocationTest
|
||||||
assertThat(routingNodes.node("node2").numberOfShardsWithState(STARTED), equalTo(2));
|
assertThat(routingNodes.node("node2").numberOfShardsWithState(STARTED), equalTo(2));
|
||||||
|
|
||||||
logger.info("Start another node and perform rerouting");
|
logger.info("Start another node and perform rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.add(newNode("node3"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("find the replica shard that gets relocated");
|
logger.info("find the replica shard that gets relocated");
|
||||||
|
@ -88,8 +92,10 @@ public class ElectReplicaAsPrimaryDuringRelocationTests extends ESAllocationTest
|
||||||
|
|
||||||
// we might have primary relocating, and the test is only for replicas, so only test in the case of replica allocation
|
// we might have primary relocating, and the test is only for replicas, so only test in the case of replica allocation
|
||||||
if (indexShardRoutingTable != null) {
|
if (indexShardRoutingTable != null) {
|
||||||
logger.info("kill the node [{}] of the primary shard for the relocating replica", indexShardRoutingTable.primaryShard().currentNodeId());
|
logger.info("kill the node [{}] of the primary shard for the relocating replica",
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).remove(indexShardRoutingTable.primaryShard().currentNodeId())).build();
|
indexShardRoutingTable.primaryShard().currentNodeId());
|
||||||
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.remove(indexShardRoutingTable.primaryShard().currentNodeId())).build();
|
||||||
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
||||||
|
|
||||||
logger.info("make sure all the primary shards are active");
|
logger.info("make sure all the primary shards are active");
|
||||||
|
|
|
@ -67,13 +67,16 @@ public class ExpectedShardSizeAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
logger.info("Adding one node and performing rerouting");
|
logger.info("Adding one node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertEquals(1, clusterState.getRoutingNodes().node("node1").numberOfShardsWithState(ShardRoutingState.INITIALIZING));
|
assertEquals(1, clusterState.getRoutingNodes().node("node1")
|
||||||
assertEquals(byteSize, clusterState.getRoutingTable().shardsWithState(ShardRoutingState.INITIALIZING).get(0).getExpectedShardSize());
|
.numberOfShardsWithState(ShardRoutingState.INITIALIZING));
|
||||||
|
assertEquals(byteSize, clusterState.getRoutingTable()
|
||||||
|
.shardsWithState(ShardRoutingState.INITIALIZING).get(0).getExpectedShardSize());
|
||||||
logger.info("Start the primary shard");
|
logger.info("Start the primary shard");
|
||||||
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
||||||
clusterState = strategy.applyStartedShards(clusterState, routingNodes.shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, routingNodes.shardsWithState(INITIALIZING));
|
||||||
|
@ -82,11 +85,14 @@ public class ExpectedShardSizeAllocationTests extends ESAllocationTestCase {
|
||||||
assertEquals(1, clusterState.getRoutingNodes().unassigned().size());
|
assertEquals(1, clusterState.getRoutingNodes().unassigned().size());
|
||||||
|
|
||||||
logger.info("Add another one node and reroute");
|
logger.info("Add another one node and reroute");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertEquals(1, clusterState.getRoutingNodes().node("node2").numberOfShardsWithState(ShardRoutingState.INITIALIZING));
|
assertEquals(1, clusterState.getRoutingNodes()
|
||||||
assertEquals(byteSize, clusterState.getRoutingTable().shardsWithState(ShardRoutingState.INITIALIZING).get(0).getExpectedShardSize());
|
.node("node2").numberOfShardsWithState(ShardRoutingState.INITIALIZING));
|
||||||
|
assertEquals(byteSize, clusterState.getRoutingTable()
|
||||||
|
.shardsWithState(ShardRoutingState.INITIALIZING).get(0).getExpectedShardSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExpectedSizeOnMove() {
|
public void testExpectedSizeOnMove() {
|
||||||
|
@ -107,10 +113,12 @@ public class ExpectedShardSizeAllocationTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("adding two nodes and performing rerouting");
|
logger.info("adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = allocation.reroute(clusterState, "reroute");
|
clusterState = allocation.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("start primary shard");
|
logger.info("start primary shard");
|
||||||
|
@ -125,7 +133,8 @@ public class ExpectedShardSizeAllocationTests extends ESAllocationTestCase {
|
||||||
toNodeId = "node1";
|
toNodeId = "node1";
|
||||||
}
|
}
|
||||||
AllocationService.CommandsResult commandsResult =
|
AllocationService.CommandsResult commandsResult =
|
||||||
allocation.reroute(clusterState, new AllocationCommands(new MoveAllocationCommand("test", 0, existingNodeId, toNodeId)), false, false);
|
allocation.reroute(clusterState, new AllocationCommands(
|
||||||
|
new MoveAllocationCommand("test", 0, existingNodeId, toNodeId)), false, false);
|
||||||
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
||||||
clusterState = commandsResult.getClusterState();
|
clusterState = commandsResult.getClusterState();
|
||||||
assertEquals(clusterState.getRoutingNodes().node(existingNodeId).iterator().next().state(), ShardRoutingState.RELOCATING);
|
assertEquals(clusterState.getRoutingNodes().node(existingNodeId).iterator().next().state(), ShardRoutingState.RELOCATING);
|
||||||
|
|
|
@ -66,7 +66,8 @@ public class FailedNodeRoutingTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(FailedNodeRoutingTests.class);
|
private final Logger logger = LogManager.getLogger(FailedNodeRoutingTests.class);
|
||||||
|
|
||||||
public void testSimpleFailedNodeTest() {
|
public void testSimpleFailedNodeTest() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -79,10 +80,12 @@ public class FailedNodeRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("start 4 nodes");
|
logger.info("start 4 nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).add(newNode("node4"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).add(newNode("node4"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("start all the primary shards, replicas will start initializing");
|
logger.info("start all the primary shards, replicas will start initializing");
|
||||||
|
|
|
@ -72,7 +72,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
|
.metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
logger.info("--> adding 2 nodes on same rack and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -109,23 +110,24 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
String origReplicaNodeId = clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId();
|
String origReplicaNodeId = clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId();
|
||||||
|
|
||||||
logger.info("--> moving primary shard to node3");
|
logger.info("--> moving primary shard to node3");
|
||||||
AllocationService.CommandsResult commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
AllocationService.CommandsResult commandsResult = allocation.reroute(clusterState, new AllocationCommands(new MoveAllocationCommand(
|
||||||
new MoveAllocationCommand("test", 0, clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), "node3")),
|
"test", 0, clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), "node3")), false, false);
|
||||||
false, false);
|
|
||||||
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
||||||
clusterState = commandsResult.getClusterState();
|
clusterState = commandsResult.getClusterState();
|
||||||
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(RELOCATING));
|
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(RELOCATING));
|
||||||
assertThat(clusterState.getRoutingNodes().node("node3").iterator().next().state(), equalTo(INITIALIZING));
|
assertThat(clusterState.getRoutingNodes().node("node3").iterator().next().state(), equalTo(INITIALIZING));
|
||||||
|
|
||||||
logger.info("--> fail primary shard recovering instance on node3 being initialized");
|
logger.info("--> fail primary shard recovering instance on node3 being initialized");
|
||||||
clusterState = allocation.applyFailedShard(clusterState, clusterState.getRoutingNodes().node("node3").iterator().next(), randomBoolean());
|
clusterState = allocation.applyFailedShard(clusterState,
|
||||||
|
clusterState.getRoutingNodes().node("node3").iterator().next(), randomBoolean());
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(STARTED));
|
assertThat(clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.getRoutingNodes().node("node3").size(), equalTo(0));
|
assertThat(clusterState.getRoutingNodes().node("node3").size(), equalTo(0));
|
||||||
|
|
||||||
logger.info("--> moving primary shard to node3");
|
logger.info("--> moving primary shard to node3");
|
||||||
commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
commandsResult = allocation.reroute(clusterState, new AllocationCommands(
|
||||||
new MoveAllocationCommand("test", 0, clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), "node3")),
|
new MoveAllocationCommand("test", 0,
|
||||||
|
clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), "node3")),
|
||||||
false, false);
|
false, false);
|
||||||
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
assertThat(commandsResult.getClusterState(), not(equalTo(clusterState)));
|
||||||
clusterState = commandsResult.getClusterState();
|
clusterState = commandsResult.getClusterState();
|
||||||
|
@ -133,12 +135,14 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.getRoutingNodes().node("node3").iterator().next().state(), equalTo(INITIALIZING));
|
assertThat(clusterState.getRoutingNodes().node("node3").iterator().next().state(), equalTo(INITIALIZING));
|
||||||
|
|
||||||
logger.info("--> fail primary shard recovering instance on node1 being relocated");
|
logger.info("--> fail primary shard recovering instance on node1 being relocated");
|
||||||
clusterState = allocation.applyFailedShard(clusterState, clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next(), randomBoolean());
|
clusterState = allocation.applyFailedShard(clusterState,
|
||||||
|
clusterState.getRoutingNodes().node(origPrimaryNodeId).iterator().next(), randomBoolean());
|
||||||
|
|
||||||
// check promotion of replica to primary
|
// check promotion of replica to primary
|
||||||
assertThat(clusterState.getRoutingNodes().node(origReplicaNodeId).iterator().next().state(), equalTo(STARTED));
|
assertThat(clusterState.getRoutingNodes().node(origReplicaNodeId).iterator().next().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(origReplicaNodeId));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(origReplicaNodeId));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), anyOf(equalTo(origPrimaryNodeId), equalTo("node3")));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
anyOf(equalTo(origPrimaryNodeId), equalTo("node3")));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testFailPrimaryStartedCheckReplicaElected() {
|
public void testFailPrimaryStartedCheckReplicaElected() {
|
||||||
|
@ -157,10 +161,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
|
.metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("Start the shards (primaries)");
|
logger.info("Start the shards (primaries)");
|
||||||
|
@ -176,10 +182,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(), anyOf(equalTo("node1"), equalTo("node2")));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(),
|
||||||
|
anyOf(equalTo("node1"), equalTo("node2")));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(), anyOf(equalTo("node2"), equalTo("node1")));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(),
|
||||||
|
anyOf(equalTo("node2"), equalTo("node1")));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("Start the shards (backups)");
|
logger.info("Start the shards (backups)");
|
||||||
|
@ -193,10 +201,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(), anyOf(equalTo("node1"), equalTo("node2")));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(),
|
||||||
|
anyOf(equalTo("node1"), equalTo("node2")));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(), anyOf(equalTo("node2"), equalTo("node1")));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(),
|
||||||
|
anyOf(equalTo("node2"), equalTo("node1")));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("fail the primary shard, will have no place to be rerouted to (single node), so stays unassigned");
|
logger.info("fail the primary shard, will have no place to be rerouted to (single node), so stays unassigned");
|
||||||
|
@ -207,9 +217,11 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), not(equalTo(shardToFail.currentNodeId())));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(),
|
||||||
|
not(equalTo(shardToFail.currentNodeId())));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), anyOf(equalTo("node1"), equalTo("node2")));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(),
|
||||||
|
anyOf(equalTo("node1"), equalTo("node2")));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(UNASSIGNED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(UNASSIGNED));
|
||||||
}
|
}
|
||||||
|
@ -230,7 +242,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding single node and performing rerouting");
|
logger.info("Adding single node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
|
@ -274,14 +287,16 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
int numberOfReplicas = scaledRandomIntBetween(2, 10);
|
int numberOfReplicas = scaledRandomIntBetween(2, 10);
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(numberOfReplicas))
|
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(1).numberOfReplicas(numberOfReplicas))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder()
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
|
.metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding {} nodes and performing rerouting", numberOfReplicas + 1);
|
logger.info("Adding {} nodes and performing rerouting", numberOfReplicas + 1);
|
||||||
DiscoveryNodes.Builder nodeBuilder = DiscoveryNodes.builder();
|
DiscoveryNodes.Builder nodeBuilder = DiscoveryNodes.builder();
|
||||||
|
@ -344,10 +359,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
|
.metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
ClusterState newState = strategy.reroute(clusterState, "reroute");
|
ClusterState newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(clusterState));
|
assertThat(newState, not(clusterState));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
@ -399,10 +416,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
|
.metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("Start the shards (primaries)");
|
logger.info("Start the shards (primaries)");
|
||||||
|
@ -416,10 +435,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).shards().size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).shards().size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(), anyOf(equalTo("node1"), equalTo("node2")));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(),
|
||||||
|
anyOf(equalTo("node1"), equalTo("node2")));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(), anyOf(equalTo("node2"), equalTo("node1")));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(),
|
||||||
|
anyOf(equalTo("node2"), equalTo("node1")));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("Start the shards (backups)");
|
logger.info("Start the shards (backups)");
|
||||||
|
@ -433,14 +454,17 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).shards().size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(i).shards().size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(), anyOf(equalTo("node1"), equalTo("node2")));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(),
|
||||||
|
anyOf(equalTo("node1"), equalTo("node2")));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(), anyOf(equalTo("node2"), equalTo("node1")));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(),
|
||||||
|
anyOf(equalTo("node2"), equalTo("node1")));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("Adding third node and reroute");
|
logger.info("Adding third node and reroute");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.add(newNode("node3"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
@ -489,7 +513,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
ShardId shardId = new ShardId(metaData.index("test").getIndex(), 0);
|
ShardId shardId = new ShardId(metaData.index("test").getIndex(), 0);
|
||||||
|
|
||||||
// add 4 nodes
|
// add 4 nodes
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).add(newNode("node4"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).add(newNode("node4"))).build();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(allocation.reroute(clusterState, "reroute").routingTable()).build();
|
clusterState = ClusterState.builder(clusterState).routingTable(allocation.reroute(clusterState, "reroute").routingTable()).build();
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(UNASSIGNED).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(UNASSIGNED).size(), equalTo(2));
|
||||||
|
@ -532,10 +557,12 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
|
.metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
// add 4 nodes
|
// add 4 nodes
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).add(newNode("node4"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))
|
||||||
|
.add(newNode("node2")).add(newNode("node3")).add(newNode("node4"))).build();
|
||||||
clusterState = allocation.reroute(clusterState, "reroute");
|
clusterState = allocation.reroute(clusterState, "reroute");
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(UNASSIGNED).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(UNASSIGNED).size(), equalTo(2));
|
||||||
|
@ -545,7 +572,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(2));
|
||||||
|
|
||||||
// start another replica shard, while keep one initializing
|
// start another replica shard, while keep one initializing
|
||||||
clusterState = allocation.applyStartedShards(clusterState, Collections.singletonList(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(0)));
|
clusterState = allocation.applyStartedShards(clusterState,
|
||||||
|
Collections.singletonList(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).get(0)));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(2));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
||||||
|
|
||||||
|
@ -579,7 +607,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
DiscoveryNodes.builder()
|
DiscoveryNodes.builder()
|
||||||
.add(newNode("node1-5.x", Version.fromId(5060099))))
|
.add(newNode("node1-5.x", Version.fromId(5060099))))
|
||||||
.build();
|
.build();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(allocation.reroute(clusterState, "reroute").routingTable()).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.routingTable(allocation.reroute(clusterState, "reroute").routingTable()).build();
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(UNASSIGNED).size(), equalTo(3));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(UNASSIGNED).size(), equalTo(3));
|
||||||
|
|
||||||
|
@ -641,8 +670,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
Version nodeVer = cursor.value.getVersion();
|
Version nodeVer = cursor.value.getVersion();
|
||||||
assertTrue("expected node [" + cursor.value.getId() + "] with version " + nodeVer + " to be before " + replicaNodeVersion,
|
assertTrue("expected node [" + cursor.value.getId() + "] with version " + nodeVer
|
||||||
replicaNodeVersion.onOrAfter(nodeVer));
|
+ " to be before " + replicaNodeVersion, replicaNodeVersion.onOrAfter(nodeVer));
|
||||||
}
|
}
|
||||||
|
|
||||||
startedReplica = clusterState.getRoutingNodes().activeReplicaWithHighestVersion(shardId);
|
startedReplica = clusterState.getRoutingNodes().activeReplicaWithHighestVersion(shardId);
|
||||||
|
@ -671,8 +700,8 @@ public class FailedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
Version nodeVer = cursor.value.getVersion();
|
Version nodeVer = cursor.value.getVersion();
|
||||||
assertTrue("expected node [" + cursor.value.getId() + "] with version " + nodeVer + " to be before " + replicaNodeVersion,
|
assertTrue("expected node [" + cursor.value.getId() + "] with version "
|
||||||
replicaNodeVersion.onOrAfter(nodeVer));
|
+ nodeVer + " to be before " + replicaNodeVersion, replicaNodeVersion.onOrAfter(nodeVer));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,12 +51,15 @@ public class IndexBalanceTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1))
|
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(3).numberOfReplicas(1))
|
||||||
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
|
.addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(3));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(3));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -80,7 +83,8 @@ public class IndexBalanceTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Adding three node and performing rerouting");
|
logger.info("Adding three node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState)
|
clusterState = ClusterState.builder(clusterState)
|
||||||
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3"))).build();
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))
|
||||||
|
.add(newNode("node3"))).build();
|
||||||
|
|
||||||
ClusterState newState = strategy.reroute(clusterState, "reroute");
|
ClusterState newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
|
@ -167,12 +171,16 @@ public class IndexBalanceTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1))
|
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT))
|
||||||
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
.numberOfShards(3).numberOfReplicas(1))
|
||||||
|
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(3).numberOfReplicas(1)).build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
|
.addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(3));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(3));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -311,11 +319,13 @@ public class IndexBalanceTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(3).numberOfReplicas(1)).build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(3));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(3));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
|
|
@ -95,7 +95,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -109,7 +110,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("start two nodes and fully start the shards");
|
logger.info("start two nodes and fully start the shards");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -187,7 +189,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
RoutingTable.Builder rtBuilder = RoutingTable.builder();
|
RoutingTable.Builder rtBuilder = RoutingTable.builder();
|
||||||
int numIndices = between(1, 20);
|
int numIndices = between(1, 20);
|
||||||
for (int i = 0; i < numIndices; i++) {
|
for (int i = 0; i < numIndices; i++) {
|
||||||
builder.put(IndexMetaData.builder("test_" + i).settings(settings(Version.CURRENT)).numberOfShards(between(1, 5)).numberOfReplicas(between(0, 2)));
|
builder.put(IndexMetaData.builder("test_" + i).settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(between(1, 5)).numberOfReplicas(between(0, 2)));
|
||||||
}
|
}
|
||||||
MetaData metaData = builder.build();
|
MetaData metaData = builder.build();
|
||||||
|
|
||||||
|
@ -196,7 +199,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
RoutingTable routingTable = rtBuilder.build();
|
RoutingTable routingTable = rtBuilder.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
assertThat(routingTable.shardsWithState(UNASSIGNED).size(), equalTo(routingTable.allShards().size()));
|
assertThat(routingTable.shardsWithState(UNASSIGNED).size(), equalTo(routingTable.allShards().size()));
|
||||||
List<DiscoveryNode> nodes = new ArrayList<>();
|
List<DiscoveryNode> nodes = new ArrayList<>();
|
||||||
int nodeIdx = 0;
|
int nodeIdx = 0;
|
||||||
|
@ -241,7 +245,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -304,20 +309,26 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
AllocationId allocationId2P = AllocationId.newInitializing();
|
AllocationId allocationId2P = AllocationId.newInitializing();
|
||||||
AllocationId allocationId2R = AllocationId.newInitializing();
|
AllocationId allocationId2R = AllocationId.newInitializing();
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder(shard1.getIndexName()).settings(settings(Version.CURRENT).put(Settings.EMPTY)).numberOfShards(1).numberOfReplicas(1).putInSyncAllocationIds(0, Sets.newHashSet(allocationId1P.getId(), allocationId1R.getId())))
|
.put(IndexMetaData.builder(shard1.getIndexName()).settings(settings(Version.CURRENT).put(Settings.EMPTY)).numberOfShards(1)
|
||||||
.put(IndexMetaData.builder(shard2.getIndexName()).settings(settings(Version.CURRENT).put(Settings.EMPTY)).numberOfShards(1).numberOfReplicas(1).putInSyncAllocationIds(0, Sets.newHashSet(allocationId2P.getId(), allocationId2R.getId())))
|
.numberOfReplicas(1).putInSyncAllocationIds(0, Sets.newHashSet(allocationId1P.getId(), allocationId1R.getId())))
|
||||||
|
.put(IndexMetaData.builder(shard2.getIndexName()).settings(settings(Version.CURRENT).put(Settings.EMPTY)).numberOfShards(1)
|
||||||
|
.numberOfReplicas(1).putInSyncAllocationIds(0, Sets.newHashSet(allocationId2P.getId(), allocationId2R.getId())))
|
||||||
.build();
|
.build();
|
||||||
RoutingTable routingTable = RoutingTable.builder()
|
RoutingTable routingTable = RoutingTable.builder()
|
||||||
.add(IndexRoutingTable.builder(shard1.getIndex())
|
.add(IndexRoutingTable.builder(shard1.getIndex())
|
||||||
.addIndexShard(new IndexShardRoutingTable.Builder(shard1)
|
.addIndexShard(new IndexShardRoutingTable.Builder(shard1)
|
||||||
.addShard(TestShardRouting.newShardRouting(shard1.getIndexName(), shard1.getId(), newNode.getId(), null, true, ShardRoutingState.STARTED, allocationId1P))
|
.addShard(TestShardRouting.newShardRouting(shard1.getIndexName(), shard1.getId(), newNode.getId(),
|
||||||
.addShard(TestShardRouting.newShardRouting(shard1.getIndexName(), shard1.getId(), oldNode1.getId(), null, false, ShardRoutingState.STARTED, allocationId1R))
|
null, true, ShardRoutingState.STARTED, allocationId1P))
|
||||||
|
.addShard(TestShardRouting.newShardRouting(shard1.getIndexName(), shard1.getId(), oldNode1.getId(),
|
||||||
|
null, false, ShardRoutingState.STARTED, allocationId1R))
|
||||||
.build())
|
.build())
|
||||||
)
|
)
|
||||||
.add(IndexRoutingTable.builder(shard2.getIndex())
|
.add(IndexRoutingTable.builder(shard2.getIndex())
|
||||||
.addIndexShard(new IndexShardRoutingTable.Builder(shard2)
|
.addIndexShard(new IndexShardRoutingTable.Builder(shard2)
|
||||||
.addShard(TestShardRouting.newShardRouting(shard2.getIndexName(), shard2.getId(), newNode.getId(), null, true, ShardRoutingState.STARTED, allocationId2P))
|
.addShard(TestShardRouting.newShardRouting(shard2.getIndexName(), shard2.getId(), newNode.getId(),
|
||||||
.addShard(TestShardRouting.newShardRouting(shard2.getIndexName(), shard2.getId(), oldNode1.getId(), null, false, ShardRoutingState.STARTED, allocationId2R))
|
null, true, ShardRoutingState.STARTED, allocationId2P))
|
||||||
|
.addShard(TestShardRouting.newShardRouting(shard2.getIndexName(), shard2.getId(), oldNode1.getId(),
|
||||||
|
null, false, ShardRoutingState.STARTED, allocationId2R))
|
||||||
.build())
|
.build())
|
||||||
)
|
)
|
||||||
.build();
|
.build();
|
||||||
|
@ -325,7 +336,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
.metaData(metaData)
|
.metaData(metaData)
|
||||||
.routingTable(routingTable)
|
.routingTable(routingTable)
|
||||||
.nodes(DiscoveryNodes.builder().add(newNode).add(oldNode1).add(oldNode2)).build();
|
.nodes(DiscoveryNodes.builder().add(newNode).add(oldNode1).add(oldNode2)).build();
|
||||||
AllocationDeciders allocationDeciders = new AllocationDeciders(Settings.EMPTY, Collections.singleton(new NodeVersionAllocationDecider(Settings.EMPTY)));
|
AllocationDeciders allocationDeciders = new AllocationDeciders(Settings.EMPTY,
|
||||||
|
Collections.singleton(new NodeVersionAllocationDecider(Settings.EMPTY)));
|
||||||
AllocationService strategy = new MockAllocationService(Settings.EMPTY,
|
AllocationService strategy = new MockAllocationService(Settings.EMPTY,
|
||||||
allocationDeciders,
|
allocationDeciders,
|
||||||
new TestGatewayAllocator(), new BalancedShardsAllocator(Settings.EMPTY), EmptyClusterInfoService.INSTANCE);
|
new TestGatewayAllocator(), new BalancedShardsAllocator(Settings.EMPTY), EmptyClusterInfoService.INSTANCE);
|
||||||
|
@ -401,16 +413,16 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
String fromId = r.currentNodeId();
|
String fromId = r.currentNodeId();
|
||||||
assertThat(fromId, notNullValue());
|
assertThat(fromId, notNullValue());
|
||||||
assertThat(toId, notNullValue());
|
assertThat(toId, notNullValue());
|
||||||
logger.trace("From: {} with Version: {} to: {} with Version: {}", fromId, routingNodes.node(fromId).node().getVersion(),
|
logger.trace("From: {} with Version: {} to: {} with Version: {}", fromId,
|
||||||
toId, routingNodes.node(toId).node().getVersion());
|
routingNodes.node(fromId).node().getVersion(), toId, routingNodes.node(toId).node().getVersion());
|
||||||
assertTrue(routingNodes.node(toId).node().getVersion().onOrAfter(routingNodes.node(fromId).node().getVersion()));
|
assertTrue(routingNodes.node(toId).node().getVersion().onOrAfter(routingNodes.node(fromId).node().getVersion()));
|
||||||
} else {
|
} else {
|
||||||
ShardRouting primary = routingNodes.activePrimary(r.shardId());
|
ShardRouting primary = routingNodes.activePrimary(r.shardId());
|
||||||
assertThat(primary, notNullValue());
|
assertThat(primary, notNullValue());
|
||||||
String fromId = primary.currentNodeId();
|
String fromId = primary.currentNodeId();
|
||||||
String toId = r.relocatingNodeId();
|
String toId = r.relocatingNodeId();
|
||||||
logger.trace("From: {} with Version: {} to: {} with Version: {}", fromId, routingNodes.node(fromId).node().getVersion(),
|
logger.trace("From: {} with Version: {} to: {} with Version: {}", fromId,
|
||||||
toId, routingNodes.node(toId).node().getVersion());
|
routingNodes.node(fromId).node().getVersion(), toId, routingNodes.node(toId).node().getVersion());
|
||||||
assertTrue(routingNodes.node(toId).node().getVersion().onOrAfter(routingNodes.node(fromId).node().getVersion()));
|
assertTrue(routingNodes.node(toId).node().getVersion().onOrAfter(routingNodes.node(fromId).node().getVersion()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -422,8 +434,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
assertThat(primary, notNullValue());
|
assertThat(primary, notNullValue());
|
||||||
String fromId = primary.currentNodeId();
|
String fromId = primary.currentNodeId();
|
||||||
String toId = r.currentNodeId();
|
String toId = r.currentNodeId();
|
||||||
logger.trace("From: {} with Version: {} to: {} with Version: {}", fromId, routingNodes.node(fromId).node().getVersion(),
|
logger.trace("From: {} with Version: {} to: {} with Version: {}", fromId,
|
||||||
toId, routingNodes.node(toId).node().getVersion());
|
routingNodes.node(fromId).node().getVersion(), toId, routingNodes.node(toId).node().getVersion());
|
||||||
assertTrue(routingNodes.node(toId).node().getVersion().onOrAfter(routingNodes.node(fromId).node().getVersion()));
|
assertTrue(routingNodes.node(toId).node().getVersion().onOrAfter(routingNodes.node(fromId).node().getVersion()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -450,7 +462,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
final ShardRouting primaryShard = clusterState.routingTable().shardRoutingTable(shardId).primaryShard();
|
final ShardRouting primaryShard = clusterState.routingTable().shardRoutingTable(shardId).primaryShard();
|
||||||
final ShardRouting replicaShard = clusterState.routingTable().shardRoutingTable(shardId).replicaShards().get(0);
|
final ShardRouting replicaShard = clusterState.routingTable().shardRoutingTable(shardId).replicaShards().get(0);
|
||||||
|
|
||||||
RoutingAllocation routingAllocation = new RoutingAllocation(null, clusterState.getRoutingNodes(), clusterState, null, 0);
|
RoutingAllocation routingAllocation = new RoutingAllocation(null, clusterState.getRoutingNodes(), clusterState,
|
||||||
|
null, 0);
|
||||||
routingAllocation.debugDecision(true);
|
routingAllocation.debugDecision(true);
|
||||||
|
|
||||||
final NodeVersionAllocationDecider allocationDecider = new NodeVersionAllocationDecider(Settings.EMPTY);
|
final NodeVersionAllocationDecider allocationDecider = new NodeVersionAllocationDecider(Settings.EMPTY);
|
||||||
|
@ -469,9 +482,11 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
newNode.node().getVersion() + "] to a node with older version [" + oldNode.node().getVersion() + "]"));
|
newNode.node().getVersion() + "] to a node with older version [" + oldNode.node().getVersion() + "]"));
|
||||||
|
|
||||||
final SnapshotRecoverySource newVersionSnapshot = new SnapshotRecoverySource(
|
final SnapshotRecoverySource newVersionSnapshot = new SnapshotRecoverySource(
|
||||||
new Snapshot("rep1", new SnapshotId("snp1", UUIDs.randomBase64UUID())), newNode.node().getVersion(), "test");
|
new Snapshot("rep1", new SnapshotId("snp1", UUIDs.randomBase64UUID())),
|
||||||
|
newNode.node().getVersion(), "test");
|
||||||
final SnapshotRecoverySource oldVersionSnapshot = new SnapshotRecoverySource(
|
final SnapshotRecoverySource oldVersionSnapshot = new SnapshotRecoverySource(
|
||||||
new Snapshot("rep1", new SnapshotId("snp1", UUIDs.randomBase64UUID())), oldNode.node().getVersion(), "test");
|
new Snapshot("rep1", new SnapshotId("snp1", UUIDs.randomBase64UUID())),
|
||||||
|
oldNode.node().getVersion(), "test");
|
||||||
|
|
||||||
decision = allocationDecider.canAllocate(ShardRoutingHelper.newWithRestoreSource(primaryShard, newVersionSnapshot),
|
decision = allocationDecider.canAllocate(ShardRoutingHelper.newWithRestoreSource(primaryShard, newVersionSnapshot),
|
||||||
oldNode, routingAllocation);
|
oldNode, routingAllocation);
|
||||||
|
@ -487,7 +502,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
final RoutingChangesObserver routingChangesObserver = new RoutingChangesObserver.AbstractRoutingChangesObserver();
|
final RoutingChangesObserver routingChangesObserver = new RoutingChangesObserver.AbstractRoutingChangesObserver();
|
||||||
final RoutingNodes routingNodes = new RoutingNodes(clusterState, false);
|
final RoutingNodes routingNodes = new RoutingNodes(clusterState, false);
|
||||||
final ShardRouting startedPrimary = routingNodes.startShard(logger, routingNodes.initializeShard(primaryShard, "newNode", null, 0,
|
final ShardRouting startedPrimary = routingNodes.startShard(logger,
|
||||||
|
routingNodes.initializeShard(primaryShard, "newNode", null, 0,
|
||||||
routingChangesObserver), routingChangesObserver);
|
routingChangesObserver), routingChangesObserver);
|
||||||
routingAllocation = new RoutingAllocation(null, routingNodes, clusterState, null, 0);
|
routingAllocation = new RoutingAllocation(null, routingNodes, clusterState, null, 0);
|
||||||
routingAllocation.debugDecision(true);
|
routingAllocation.debugDecision(true);
|
||||||
|
@ -497,8 +513,8 @@ public class NodeVersionAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
assertThat(decision.getExplanation(), is("cannot allocate replica shard to a node with version [" +
|
assertThat(decision.getExplanation(), is("cannot allocate replica shard to a node with version [" +
|
||||||
oldNode.node().getVersion() + "] since this is older than the primary version [" + newNode.node().getVersion() + "]"));
|
oldNode.node().getVersion() + "] since this is older than the primary version [" + newNode.node().getVersion() + "]"));
|
||||||
|
|
||||||
routingNodes.startShard(logger, routingNodes.relocateShard(startedPrimary, "oldNode", 0, routingChangesObserver).v2(),
|
routingNodes.startShard(logger, routingNodes.relocateShard(startedPrimary,
|
||||||
routingChangesObserver);
|
"oldNode", 0, routingChangesObserver).v2(), routingChangesObserver);
|
||||||
routingAllocation = new RoutingAllocation(null, routingNodes, clusterState, null, 0);
|
routingAllocation = new RoutingAllocation(null, routingNodes, clusterState, null, 0);
|
||||||
routingAllocation.debugDecision(true);
|
routingAllocation.debugDecision(true);
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,8 @@ public class PreferLocalPrimariesToRelocatingPrimariesTests extends ESAllocation
|
||||||
int numberOfShards = randomIntBetween(5, 20);
|
int numberOfShards = randomIntBetween(5, 20);
|
||||||
int totalNumberOfShards = numberOfShards * 2;
|
int totalNumberOfShards = numberOfShards * 2;
|
||||||
|
|
||||||
logger.info("create an allocation with [{}] initial primary recoveries and [{}] concurrent recoveries", primaryRecoveries, concurrentRecoveries);
|
logger.info("create an allocation with [{}] initial primary recoveries and [{}] concurrent recoveries",
|
||||||
|
primaryRecoveries, concurrentRecoveries);
|
||||||
AllocationService strategy = createAllocationService(Settings.builder()
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
.put("cluster.routing.allocation.node_concurrent_recoveries", concurrentRecoveries)
|
.put("cluster.routing.allocation.node_concurrent_recoveries", concurrentRecoveries)
|
||||||
.put("cluster.routing.allocation.node_initial_primaries_recoveries", primaryRecoveries)
|
.put("cluster.routing.allocation.node_initial_primaries_recoveries", primaryRecoveries)
|
||||||
|
@ -52,8 +53,10 @@ public class PreferLocalPrimariesToRelocatingPrimariesTests extends ESAllocation
|
||||||
logger.info("create 2 indices with [{}] no replicas, and wait till all are allocated", numberOfShards);
|
logger.info("create 2 indices with [{}] no replicas, and wait till all are allocated", numberOfShards);
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(numberOfShards).numberOfReplicas(0))
|
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT))
|
||||||
.put(IndexMetaData.builder("test2").settings(settings(Version.CURRENT)).numberOfShards(numberOfShards).numberOfReplicas(0))
|
.numberOfShards(numberOfShards).numberOfReplicas(0))
|
||||||
|
.put(IndexMetaData.builder("test2").settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(numberOfShards).numberOfReplicas(0))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder()
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
|
@ -61,7 +64,8 @@ public class PreferLocalPrimariesToRelocatingPrimariesTests extends ESAllocation
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("adding two nodes and performing rerouting till all are allocated");
|
logger.info("adding two nodes and performing rerouting till all are allocated");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -88,10 +92,12 @@ public class PreferLocalPrimariesToRelocatingPrimariesTests extends ESAllocation
|
||||||
.put("index.routing.allocation.exclude._name", "node2")
|
.put("index.routing.allocation.exclude._name", "node2")
|
||||||
.build()))
|
.build()))
|
||||||
.build();
|
.build();
|
||||||
clusterState = ClusterState.builder(clusterState).metaData(metaData).nodes(DiscoveryNodes.builder(clusterState.nodes()).remove("node1")).build();
|
clusterState = ClusterState.builder(clusterState).metaData(metaData)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).remove("node1")).build();
|
||||||
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
||||||
|
|
||||||
logger.info("[{}] primaries should be still started but [{}] other primaries should be unassigned", numberOfShards, numberOfShards);
|
logger.info("[{}] primaries should be still started but [{}] other primaries should be unassigned",
|
||||||
|
numberOfShards, numberOfShards);
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(numberOfShards));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(numberOfShards));
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(0));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(0));
|
||||||
assertThat(clusterState.routingTable().shardsWithState(UNASSIGNED).size(), equalTo(numberOfShards));
|
assertThat(clusterState.routingTable().shardsWithState(UNASSIGNED).size(), equalTo(numberOfShards));
|
||||||
|
@ -111,8 +117,10 @@ public class PreferLocalPrimariesToRelocatingPrimariesTests extends ESAllocation
|
||||||
relocatingInitializations++;
|
relocatingInitializations++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
int needToInitialize = totalNumberOfShards - clusterState.getRoutingNodes().shardsWithState(STARTED).size() - clusterState.getRoutingNodes().shardsWithState(RELOCATING).size();
|
int needToInitialize = totalNumberOfShards - clusterState.getRoutingNodes().shardsWithState(STARTED).size()
|
||||||
logger.info("local initializations: [{}], relocating: [{}], need to initialize: {}", localInitializations, relocatingInitializations, needToInitialize);
|
- clusterState.getRoutingNodes().shardsWithState(RELOCATING).size();
|
||||||
|
logger.info("local initializations: [{}], relocating: [{}], need to initialize: {}",
|
||||||
|
localInitializations, relocatingInitializations, needToInitialize);
|
||||||
assertThat(localInitializations, equalTo(Math.min(primaryRecoveries, needToInitialize)));
|
assertThat(localInitializations, equalTo(Math.min(primaryRecoveries, needToInitialize)));
|
||||||
clusterState = startRandomInitializingShard(clusterState, strategy);
|
clusterState = startRandomInitializingShard(clusterState, strategy);
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,10 +57,12 @@ public class PreferPrimaryAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("adding two nodes and performing rerouting till all are allocated");
|
logger.info("adding two nodes and performing rerouting till all are allocated");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
while (!clusterState.getRoutingNodes().shardsWithState(INITIALIZING).isEmpty()) {
|
while (!clusterState.getRoutingNodes().shardsWithState(INITIALIZING).isEmpty()) {
|
||||||
|
|
|
@ -41,7 +41,8 @@ public class PrimaryElectionRoutingTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(PrimaryElectionRoutingTests.class);
|
private final Logger logger = LogManager.getLogger(PrimaryElectionRoutingTests.class);
|
||||||
|
|
||||||
public void testBackupElectionToPrimaryWhenPrimaryCanBeAllocatedToAnotherNode() {
|
public void testBackupElectionToPrimaryWhenPrimaryCanBeAllocatedToAnotherNode() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -53,13 +54,15 @@ public class PrimaryElectionRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("Start the primary shard (on node1)");
|
logger.info("Start the primary shard (on node1)");
|
||||||
|
@ -71,7 +74,8 @@ public class PrimaryElectionRoutingTests extends ESAllocationTestCase {
|
||||||
clusterState = strategy.applyStartedShards(clusterState, routingNodes.node("node2").shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, routingNodes.node("node2").shardsWithState(INITIALIZING));
|
||||||
|
|
||||||
logger.info("Adding third node and reroute and kill first node");
|
logger.info("Adding third node and reroute and kill first node");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3")).remove("node1")).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.add(newNode("node3")).remove("node1")).build();
|
||||||
RoutingTable prevRoutingTable = clusterState.routingTable();
|
RoutingTable prevRoutingTable = clusterState.routingTable();
|
||||||
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
|
@ -89,7 +93,8 @@ public class PrimaryElectionRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testRemovingInitializingReplicasIfPrimariesFails() {
|
public void testRemovingInitializingReplicasIfPrimariesFails() {
|
||||||
AllocationService allocation = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService allocation = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -101,10 +106,12 @@ public class PrimaryElectionRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))
|
||||||
|
.add(newNode("node2"))).build();
|
||||||
clusterState = allocation.reroute(clusterState, "reroute");
|
clusterState = allocation.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
logger.info("Start the primary shards");
|
logger.info("Start the primary shards");
|
||||||
|
|
|
@ -55,7 +55,8 @@ public class PrimaryNotRelocatedWhileBeingRecoveredTests extends ESAllocationTes
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
|
@ -68,14 +69,16 @@ public class PrimaryNotRelocatedWhileBeingRecoveredTests extends ESAllocationTes
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
||||||
|
|
||||||
logger.info("start another node, replica will start recovering form primary");
|
logger.info("start another node, replica will start recovering form primary");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
||||||
assertThat(clusterState.routingTable().shardsWithState(INITIALIZING).size(), equalTo(5));
|
assertThat(clusterState.routingTable().shardsWithState(INITIALIZING).size(), equalTo(5));
|
||||||
|
|
||||||
logger.info("start another node, make sure the primary is not relocated");
|
logger.info("start another node, make sure the primary is not relocated");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
||||||
|
|
|
@ -60,8 +60,9 @@ public class RandomAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
RandomAllocationDecider randomAllocationDecider = new RandomAllocationDecider(random());
|
RandomAllocationDecider randomAllocationDecider = new RandomAllocationDecider(random());
|
||||||
AllocationService strategy = new AllocationService(Settings.builder().build(), new AllocationDeciders(Settings.EMPTY,
|
AllocationService strategy = new AllocationService(Settings.builder().build(), new AllocationDeciders(Settings.EMPTY,
|
||||||
new HashSet<>(Arrays.asList(new SameShardAllocationDecider(Settings.EMPTY,
|
new HashSet<>(Arrays.asList(new SameShardAllocationDecider(Settings.EMPTY,
|
||||||
new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS)), new ReplicaAfterPrimaryActiveAllocationDecider(Settings.EMPTY),
|
new ClusterSettings(Settings.EMPTY, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS)),
|
||||||
randomAllocationDecider))), new TestGatewayAllocator(), new BalancedShardsAllocator(Settings.EMPTY), EmptyClusterInfoService.INSTANCE);
|
new ReplicaAfterPrimaryActiveAllocationDecider(Settings.EMPTY), randomAllocationDecider))),
|
||||||
|
new TestGatewayAllocator(), new BalancedShardsAllocator(Settings.EMPTY), EmptyClusterInfoService.INSTANCE);
|
||||||
int indices = scaledRandomIntBetween(1, 20);
|
int indices = scaledRandomIntBetween(1, 20);
|
||||||
Builder metaBuilder = MetaData.builder();
|
Builder metaBuilder = MetaData.builder();
|
||||||
int maxNumReplicas = 1;
|
int maxNumReplicas = 1;
|
||||||
|
@ -71,7 +72,8 @@ public class RandomAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
maxNumReplicas = Math.max(maxNumReplicas, replicas + 1);
|
maxNumReplicas = Math.max(maxNumReplicas, replicas + 1);
|
||||||
int numShards = scaledRandomIntBetween(1, 20);
|
int numShards = scaledRandomIntBetween(1, 20);
|
||||||
totalNumShards += numShards * (replicas + 1);
|
totalNumShards += numShards * (replicas + 1);
|
||||||
metaBuilder.put(IndexMetaData.builder("INDEX_" + i).settings(settings(Version.CURRENT)).numberOfShards(numShards).numberOfReplicas(replicas));
|
metaBuilder.put(IndexMetaData.builder("INDEX_" + i).settings(settings(Version.CURRENT))
|
||||||
|
.numberOfShards(numShards).numberOfReplicas(replicas));
|
||||||
|
|
||||||
}
|
}
|
||||||
MetaData metaData = metaBuilder.build();
|
MetaData metaData = metaBuilder.build();
|
||||||
|
@ -81,7 +83,8 @@ public class RandomAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = routingTableBuilder.build();
|
RoutingTable initialRoutingTable = routingTableBuilder.build();
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
int numIters = scaledRandomIntBetween(5, 15);
|
int numIters = scaledRandomIntBetween(5, 15);
|
||||||
int nodeIdCounter = 0;
|
int nodeIdCounter = 0;
|
||||||
int atMostNodes = scaledRandomIntBetween(Math.max(1, maxNumReplicas), 15);
|
int atMostNodes = scaledRandomIntBetween(Math.max(1, maxNumReplicas), 15);
|
||||||
|
@ -175,7 +178,8 @@ public class RandomAllocationDeciderTests extends ESAllocationTestCase {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
assertThat(clusterState.getRoutingNodes().node("NODE_" + i).size(), Matchers.anyOf(
|
assertThat(clusterState.getRoutingNodes().node("NODE_" + i).size(), Matchers.anyOf(
|
||||||
Matchers.anyOf(equalTo((shards / numNodes) + 1), equalTo((shards / numNodes) - 1), equalTo((shards / numNodes))),
|
Matchers.anyOf(equalTo((shards / numNodes) + 1),
|
||||||
|
equalTo((shards / numNodes) - 1), equalTo((shards / numNodes))),
|
||||||
Matchers.allOf(Matchers.greaterThanOrEqualTo(lowerBound), Matchers.lessThanOrEqualTo(upperBound))));
|
Matchers.allOf(Matchers.greaterThanOrEqualTo(lowerBound), Matchers.lessThanOrEqualTo(upperBound))));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,7 +75,8 @@ public class RebalanceAfterActiveTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(5));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -87,7 +88,8 @@ public class RebalanceAfterActiveTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("start two nodes and fully start the shards");
|
logger.info("start two nodes and fully start the shards");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -110,7 +112,8 @@ public class RebalanceAfterActiveTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("now, start 8 more nodes, and check that no rebalancing/relocation have happened");
|
logger.info("now, start 8 more nodes, and check that no rebalancing/relocation have happened");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
.add(newNode("node3")).add(newNode("node4")).add(newNode("node5")).add(newNode("node6")).add(newNode("node7")).add(newNode("node8")).add(newNode("node9")).add(newNode("node10")))
|
.add(newNode("node3")).add(newNode("node4")).add(newNode("node5")).add(newNode("node6"))
|
||||||
|
.add(newNode("node7")).add(newNode("node8")).add(newNode("node9")).add(newNode("node10")))
|
||||||
.build();
|
.build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
|
|
|
@ -42,7 +42,8 @@ public class ReplicaAllocatedAfterPrimaryTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(ReplicaAllocatedAfterPrimaryTests.class);
|
private final Logger logger = LogManager.getLogger(ReplicaAllocatedAfterPrimaryTests.class);
|
||||||
|
|
||||||
public void testBackupIsAllocatedAfterPrimary() {
|
public void testBackupIsAllocatedAfterPrimary() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -54,7 +55,8 @@ public class ReplicaAllocatedAfterPrimaryTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
assertThat(routingTable.index("test").shards().size(), equalTo(1));
|
assertThat(routingTable.index("test").shards().size(), equalTo(1));
|
||||||
assertThat(routingTable.index("test").shard(0).size(), equalTo(2));
|
assertThat(routingTable.index("test").shard(0).size(), equalTo(2));
|
||||||
|
@ -65,7 +67,8 @@ public class ReplicaAllocatedAfterPrimaryTests extends ESAllocationTestCase {
|
||||||
assertThat(routingTable.index("test").shard(0).shards().get(1).currentNodeId(), nullValue());
|
assertThat(routingTable.index("test").shard(0).shards().get(1).currentNodeId(), nullValue());
|
||||||
|
|
||||||
logger.info("Adding one node and performing rerouting");
|
logger.info("Adding one node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
|
|
||||||
RoutingTable prevRoutingTable = routingTable;
|
RoutingTable prevRoutingTable = routingTable;
|
||||||
routingTable = strategy.reroute(clusterState, "reroute").routingTable();
|
routingTable = strategy.reroute(clusterState, "reroute").routingTable();
|
||||||
|
@ -86,7 +89,8 @@ public class ReplicaAllocatedAfterPrimaryTests extends ESAllocationTestCase {
|
||||||
logger.info("Start all the primary shards");
|
logger.info("Start all the primary shards");
|
||||||
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
||||||
prevRoutingTable = routingTable;
|
prevRoutingTable = routingTable;
|
||||||
routingTable = strategy.applyStartedShards(clusterState, routingNodes.node(nodeHoldingPrimary).shardsWithState(INITIALIZING)).routingTable();
|
routingTable = strategy.applyStartedShards(clusterState,
|
||||||
|
routingNodes.node(nodeHoldingPrimary).shardsWithState(INITIALIZING)).routingTable();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
||||||
final String nodeHoldingReplica = routingTable.index("test").shard(0).replicaShards().get(0).currentNodeId();
|
final String nodeHoldingReplica = routingTable.index("test").shard(0).replicaShards().get(0).currentNodeId();
|
||||||
assertThat(nodeHoldingPrimary, not(equalTo(nodeHoldingReplica)));
|
assertThat(nodeHoldingPrimary, not(equalTo(nodeHoldingReplica)));
|
||||||
|
|
|
@ -51,12 +51,15 @@ public class RoutingNodesIntegrityTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1))
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1))
|
||||||
|
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
|
.addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding three node and performing rerouting");
|
logger.info("Adding three node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState)
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
@ -111,12 +114,15 @@ public class RoutingNodesIntegrityTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1))
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1))
|
||||||
|
.put(IndexMetaData.builder("test1").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
|
.addAsNew(metaData.index("test")).addAsNew(metaData.index("test1")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding one node and performing rerouting");
|
logger.info("Adding one node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
|
@ -191,15 +197,17 @@ public class RoutingNodesIntegrityTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
MetaData metaData = MetaData.builder()
|
||||||
|
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)).numberOfShards(3).numberOfReplicas(1)).build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Adding three node and performing rerouting");
|
logger.info("Adding three node and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState)
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))
|
||||||
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3"))).build();
|
.add(newNode("node2")).add(newNode("node3"))).build();
|
||||||
|
|
||||||
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
||||||
assertThat(assertShardStats(routingNodes), equalTo(true));
|
assertThat(assertShardStats(routingNodes), equalTo(true));
|
||||||
|
@ -324,7 +332,8 @@ public class RoutingNodesIntegrityTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("kill one node");
|
logger.info("kill one node");
|
||||||
IndexShardRoutingTable indexShardRoutingTable = clusterState.routingTable().index("test").shard(0);
|
IndexShardRoutingTable indexShardRoutingTable = clusterState.routingTable().index("test").shard(0);
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).remove(indexShardRoutingTable.primaryShard().currentNodeId())).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.remove(indexShardRoutingTable.primaryShard().currentNodeId())).build();
|
||||||
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
clusterState = strategy.deassociateDeadNodes(clusterState, true, "reroute");
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,8 @@ public class ShardVersioningTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(ShardVersioningTests.class);
|
private final Logger logger = LogManager.getLogger(ShardVersioningTests.class);
|
||||||
|
|
||||||
public void testSimple() {
|
public void testSimple() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put(ClusterRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_ALLOW_REBALANCE_SETTING.getKey(),
|
||||||
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build());
|
ClusterRebalanceAllocationDecider.ClusterRebalanceType.ALWAYS.toString()).build());
|
||||||
|
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
|
@ -54,10 +55,12 @@ public class ShardVersioningTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test2"))
|
.addAsNew(metaData.index("test2"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("start two nodes");
|
logger.info("start two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
routingTable = strategy.reroute(clusterState, "reroute").routingTable();
|
routingTable = strategy.reroute(clusterState, "reroute").routingTable();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,8 @@ public class ShardsLimitAllocationTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(ShardsLimitAllocationTests.class);
|
private final Logger logger = LogManager.getLogger(ShardsLimitAllocationTests.class);
|
||||||
|
|
||||||
public void testIndexLevelShardsLimitAllocate() {
|
public void testIndexLevelShardsLimitAllocate() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -59,9 +60,11 @@ public class ShardsLimitAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
.add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().node("node1").numberOfShardsWithState(ShardRoutingState.INITIALIZING), equalTo(2));
|
assertThat(clusterState.getRoutingNodes().node("node1").numberOfShardsWithState(ShardRoutingState.INITIALIZING), equalTo(2));
|
||||||
|
@ -100,9 +103,11 @@ public class ShardsLimitAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().node("node1").numberOfShardsWithState(ShardRoutingState.INITIALIZING), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().node("node1").numberOfShardsWithState(ShardRoutingState.INITIALIZING), equalTo(1));
|
||||||
|
@ -159,7 +164,8 @@ public class ShardsLimitAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
logger.info("Adding one node and reroute");
|
logger.info("Adding one node and reroute");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
@ -184,7 +190,8 @@ public class ShardsLimitAllocationTests extends ESAllocationTestCase {
|
||||||
clusterState = ClusterState.builder(clusterState).metaData(metaData).routingTable(updatedRoutingTable).build();
|
clusterState = ClusterState.builder(clusterState).metaData(metaData).routingTable(updatedRoutingTable).build();
|
||||||
|
|
||||||
logger.info("Add another one node and reroute");
|
logger.info("Add another one node and reroute");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
|
@ -199,7 +206,8 @@ public class ShardsLimitAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(shardRouting.getIndexName(), equalTo("test1"));
|
assertThat(shardRouting.getIndexName(), equalTo("test1"));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("update {} for test, see that things move", ShardsLimitAllocationDecider.INDEX_TOTAL_SHARDS_PER_NODE_SETTING.getKey());
|
logger.info("update {} for test, see that things move",
|
||||||
|
ShardsLimitAllocationDecider.INDEX_TOTAL_SHARDS_PER_NODE_SETTING.getKey());
|
||||||
metaData = MetaData.builder(clusterState.metaData())
|
metaData = MetaData.builder(clusterState.metaData())
|
||||||
.put(IndexMetaData.builder(clusterState.metaData().index("test")).settings(settings(Version.CURRENT)
|
.put(IndexMetaData.builder(clusterState.metaData().index("test")).settings(settings(Version.CURRENT)
|
||||||
.put(IndexMetaData.SETTING_NUMBER_OF_SHARDS, 5)
|
.put(IndexMetaData.SETTING_NUMBER_OF_SHARDS, 5)
|
||||||
|
|
|
@ -53,7 +53,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(SingleShardNoReplicasRoutingTests.class);
|
private final Logger logger = LogManager.getLogger(SingleShardNoReplicasRoutingTests.class);
|
||||||
|
|
||||||
public void testSingleIndexStartedShard() {
|
public void testSingleIndexStartedShard() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -63,7 +64,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
RoutingTable initialRoutingTable = RoutingTable.builder().addAsNew(metaData.index("test")).build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(1));
|
||||||
|
@ -100,7 +102,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).shards().get(0).currentNodeId(), equalTo("node1"));
|
assertThat(clusterState.routingTable().index("test").shard(0).shards().get(0).currentNodeId(), equalTo("node1"));
|
||||||
|
|
||||||
logger.info("Starting another node and making sure nothing changed");
|
logger.info("Starting another node and making sure nothing changed");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, equalTo(clusterState));
|
assertThat(newState, equalTo(clusterState));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
@ -126,7 +129,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Bring node1 back, and see it's assinged");
|
logger.info("Bring node1 back, and see it's assinged");
|
||||||
|
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node1"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node1"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
@ -139,7 +143,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
|
|
||||||
logger.info("Start another node, make sure that things remain the same (shard is in node2 and initializing)");
|
logger.info("Start another node, make sure that things remain the same (shard is in node2 and initializing)");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, equalTo(clusterState));
|
assertThat(newState, equalTo(clusterState));
|
||||||
|
|
||||||
|
@ -157,7 +162,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testSingleIndexShardFailed() {
|
public void testSingleIndexShardFailed() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -168,7 +174,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
RoutingTable.Builder routingTableBuilder = RoutingTable.builder()
|
RoutingTable.Builder routingTableBuilder = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"));
|
.addAsNew(metaData.index("test"));
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(1));
|
||||||
|
@ -191,7 +198,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
logger.info("Marking the shard as failed");
|
logger.info("Marking the shard as failed");
|
||||||
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
RoutingNodes routingNodes = clusterState.getRoutingNodes();
|
||||||
newState = strategy.applyFailedShard(clusterState, routingNodes.node("node1").shardsWithState(INITIALIZING).get(0), randomBoolean());
|
newState = strategy.applyFailedShard(clusterState,
|
||||||
|
routingNodes.node("node1").shardsWithState(INITIALIZING).get(0), randomBoolean());
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
|
||||||
|
@ -214,7 +222,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
MetaData.Builder metaDataBuilder = MetaData.builder();
|
MetaData.Builder metaDataBuilder = MetaData.builder();
|
||||||
for (int i = 0; i < numberOfIndices; i++) {
|
for (int i = 0; i < numberOfIndices; i++) {
|
||||||
metaDataBuilder.put(IndexMetaData.builder("test" + i).settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(0));
|
metaDataBuilder.put(IndexMetaData.builder("test" + i)
|
||||||
|
.settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(0));
|
||||||
}
|
}
|
||||||
MetaData metaData = metaDataBuilder.build();
|
MetaData metaData = metaDataBuilder.build();
|
||||||
|
|
||||||
|
@ -222,7 +231,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
for (int i = 0; i < numberOfIndices; i++) {
|
for (int i = 0; i < numberOfIndices; i++) {
|
||||||
routingTableBuilder.addAsNew(metaData.index("test" + i));
|
routingTableBuilder.addAsNew(metaData.index("test" + i));
|
||||||
}
|
}
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().indicesRouting().size(), equalTo(numberOfIndices));
|
assertThat(clusterState.routingTable().indicesRouting().size(), equalTo(numberOfIndices));
|
||||||
for (int i = 0; i < numberOfIndices; i++) {
|
for (int i = 0; i < numberOfIndices; i++) {
|
||||||
|
@ -291,7 +301,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).unassigned(), equalTo(false));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).unassigned(), equalTo(false));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state(), anyOf(equalTo(STARTED), equalTo(RELOCATING)));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state(),
|
||||||
|
anyOf(equalTo(STARTED), equalTo(RELOCATING)));
|
||||||
if (clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state() == STARTED) {
|
if (clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state() == STARTED) {
|
||||||
numberOfStartedShards++;
|
numberOfStartedShards++;
|
||||||
} else if (clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state() == RELOCATING) {
|
} else if (clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state() == RELOCATING) {
|
||||||
|
@ -319,7 +330,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
MetaData.Builder metaDataBuilder = MetaData.builder();
|
MetaData.Builder metaDataBuilder = MetaData.builder();
|
||||||
for (int i = 0; i < numberOfIndices; i++) {
|
for (int i = 0; i < numberOfIndices; i++) {
|
||||||
metaDataBuilder.put(IndexMetaData.builder("test" + i).settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(0));
|
metaDataBuilder.put(IndexMetaData.builder("test" + i)
|
||||||
|
.settings(settings(Version.CURRENT)).numberOfShards(1).numberOfReplicas(0));
|
||||||
}
|
}
|
||||||
MetaData metaData = metaDataBuilder.build();
|
MetaData metaData = metaDataBuilder.build();
|
||||||
|
|
||||||
|
@ -328,7 +340,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
routingTableBuilder.addAsNew(metaData.index("test" + i));
|
routingTableBuilder.addAsNew(metaData.index("test" + i));
|
||||||
}
|
}
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().indicesRouting().size(), equalTo(numberOfIndices));
|
assertThat(clusterState.routingTable().indicesRouting().size(), equalTo(numberOfIndices));
|
||||||
|
|
||||||
|
@ -369,7 +382,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state(), anyOf(equalTo(RELOCATING), equalTo(STARTED)));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state(),
|
||||||
|
anyOf(equalTo(RELOCATING), equalTo(STARTED)));
|
||||||
}
|
}
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
assertThat("4 source shard routing are relocating", numberOfShardsOfType(routingNodes, RELOCATING), equalTo(4));
|
assertThat("4 source shard routing are relocating", numberOfShardsOfType(routingNodes, RELOCATING), equalTo(4));
|
||||||
|
@ -385,7 +399,8 @@ public class SingleShardNoReplicasRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state(), anyOf(equalTo(RELOCATING), equalTo(STARTED)));
|
assertThat(clusterState.routingTable().index("test" + i).shard(0).shards().get(0).state(),
|
||||||
|
anyOf(equalTo(RELOCATING), equalTo(STARTED)));
|
||||||
}
|
}
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
assertThat(numberOfShardsOfType(routingNodes, STARTED), equalTo(numberOfIndices));
|
assertThat(numberOfShardsOfType(routingNodes, STARTED), equalTo(numberOfIndices));
|
||||||
|
|
|
@ -42,7 +42,8 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(SingleShardOneReplicaRoutingTests.class);
|
private final Logger logger = LogManager.getLogger(SingleShardOneReplicaRoutingTests.class);
|
||||||
|
|
||||||
public void testSingleIndexFirstStartPrimaryThenBackups() {
|
public void testSingleIndexFirstStartPrimaryThenBackups() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -54,7 +55,8 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).size(), equalTo(2));
|
||||||
|
@ -81,7 +83,8 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), nullValue());
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), nullValue());
|
||||||
|
|
||||||
logger.info("Add another node and perform rerouting, nothing will happen since primary shards not started");
|
logger.info("Add another node and perform rerouting, nothing will happen since primary shards not started");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, equalTo(clusterState));
|
assertThat(newState, equalTo(clusterState));
|
||||||
|
|
||||||
|
@ -97,9 +100,11 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node1"));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node1"));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
// backup shards are initializing as well, we make sure that they recover from primary *started* shards in the IndicesClusterStateService
|
// backup shards are initializing as well, we make sure that they recover
|
||||||
|
// from primary *started* shards in the IndicesClusterStateService
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), equalTo("node2"));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
equalTo("node2"));
|
||||||
|
|
||||||
|
|
||||||
logger.info("Reroute, nothing should change");
|
logger.info("Reroute, nothing should change");
|
||||||
|
@ -119,7 +124,8 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node1"));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node1"));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), equalTo("node2"));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
equalTo("node2"));
|
||||||
|
|
||||||
logger.info("Kill node1, backup shard should become primary");
|
logger.info("Kill node1, backup shard should become primary");
|
||||||
|
|
||||||
|
@ -134,13 +140,15 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node2"));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node2"));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
// backup shards are initializing as well, we make sure that they recover from primary *started* shards in the IndicesClusterStateService
|
// backup shards are initializing as well, we make sure that they
|
||||||
|
// recover from primary *started* shards in the IndicesClusterStateService
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(UNASSIGNED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(UNASSIGNED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), nullValue());
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), nullValue());
|
||||||
|
|
||||||
logger.info("Start another node, backup shard should start initializing");
|
logger.info("Start another node, backup shard should start initializing");
|
||||||
|
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
@ -151,8 +159,10 @@ public class SingleShardOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node2"));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo("node2"));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
// backup shards are initializing as well, we make sure that they recover from primary *started* shards in the IndicesClusterStateService
|
// backup shards are initializing as well, we make sure that they
|
||||||
|
// recover from primary *started* shards in the IndicesClusterStateService
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), equalTo("node3"));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,8 +62,10 @@ public class StartedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")))
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")))
|
||||||
.metaData(MetaData.builder().put(indexMetaData, false));
|
.metaData(MetaData.builder().put(indexMetaData, false));
|
||||||
|
|
||||||
final ShardRouting initShard = TestShardRouting.newShardRouting(new ShardId(index, 0), "node1", true, ShardRoutingState.INITIALIZING);
|
final ShardRouting initShard = TestShardRouting.newShardRouting(new ShardId(index, 0), "node1",
|
||||||
final ShardRouting relocatingShard = TestShardRouting.newShardRouting(new ShardId(index, 1), "node1", "node2", true, ShardRoutingState.RELOCATING, allocationId);
|
true, ShardRoutingState.INITIALIZING);
|
||||||
|
final ShardRouting relocatingShard = TestShardRouting.newShardRouting(new ShardId(index, 1), "node1",
|
||||||
|
"node2", true, ShardRoutingState.RELOCATING, allocationId);
|
||||||
stateBuilder.routingTable(RoutingTable.builder().add(IndexRoutingTable.builder(index)
|
stateBuilder.routingTable(RoutingTable.builder().add(IndexRoutingTable.builder(index)
|
||||||
.addIndexShard(new IndexShardRoutingTable.Builder(initShard.shardId()).addShard(initShard).build())
|
.addIndexShard(new IndexShardRoutingTable.Builder(initShard.shardId()).addShard(initShard).build())
|
||||||
.addIndexShard(new IndexShardRoutingTable.Builder(relocatingShard.shardId()).addShard(relocatingShard).build())).build());
|
.addIndexShard(new IndexShardRoutingTable.Builder(relocatingShard.shardId()).addShard(relocatingShard).build())).build());
|
||||||
|
@ -73,7 +75,8 @@ public class StartedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
logger.info("--> test starting of shard");
|
logger.info("--> test starting of shard");
|
||||||
|
|
||||||
ClusterState newState = allocation.applyStartedShards(state, Arrays.asList(initShard));
|
ClusterState newState = allocation.applyStartedShards(state, Arrays.asList(initShard));
|
||||||
assertThat("failed to start " + initShard + "\ncurrent routing table:" + newState.routingTable(), newState, not(equalTo(state)));
|
assertThat("failed to start " + initShard + "\ncurrent routing table:" +
|
||||||
|
newState.routingTable(), newState, not(equalTo(state)));
|
||||||
assertTrue(initShard + "isn't started \ncurrent routing table:" + newState.routingTable(),
|
assertTrue(initShard + "isn't started \ncurrent routing table:" + newState.routingTable(),
|
||||||
newState.routingTable().index("test").shard(initShard.id()).allShardsStarted());
|
newState.routingTable().index("test").shard(initShard.id()).allShardsStarted());
|
||||||
state = newState;
|
state = newState;
|
||||||
|
@ -107,11 +110,12 @@ public class StartedShardsRoutingTests extends ESAllocationTestCase {
|
||||||
.build();
|
.build();
|
||||||
final Index index = indexMetaData.getIndex();
|
final Index index = indexMetaData.getIndex();
|
||||||
ClusterState.Builder stateBuilder = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
ClusterState.Builder stateBuilder = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
||||||
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).add(newNode("node4")))
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))
|
||||||
|
.add(newNode("node3")).add(newNode("node4")))
|
||||||
.metaData(MetaData.builder().put(indexMetaData, false));
|
.metaData(MetaData.builder().put(indexMetaData, false));
|
||||||
|
|
||||||
final ShardRouting relocatingPrimary = TestShardRouting.newShardRouting(
|
final ShardRouting relocatingPrimary = TestShardRouting.newShardRouting(new ShardId(index, 0), "node1",
|
||||||
new ShardId(index, 0), "node1", "node2", true, ShardRoutingState.RELOCATING, primaryId);
|
"node2", true, ShardRoutingState.RELOCATING, primaryId);
|
||||||
final ShardRouting replica = TestShardRouting.newShardRouting(
|
final ShardRouting replica = TestShardRouting.newShardRouting(
|
||||||
new ShardId(index, 0), "node3", relocatingReplica ? "node4" : null, false,
|
new ShardId(index, 0), "node3", relocatingReplica ? "node4" : null, false,
|
||||||
relocatingReplica ? ShardRoutingState.RELOCATING : ShardRoutingState.INITIALIZING, replicaId);
|
relocatingReplica ? ShardRoutingState.RELOCATING : ShardRoutingState.INITIALIZING, replicaId);
|
||||||
|
|
|
@ -65,7 +65,8 @@ public class TenShardsOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(10));
|
assertThat(clusterState.routingTable().index("test").shards().size(), equalTo(10));
|
||||||
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
for (int i = 0; i < clusterState.routingTable().index("test").shards().size(); i++) {
|
||||||
|
@ -96,7 +97,8 @@ public class TenShardsOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("Add another node and perform rerouting, nothing will happen since primary not started");
|
logger.info("Add another node and perform rerouting, nothing will happen since primary not started");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes())
|
||||||
|
.add(newNode("node2"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, equalTo(clusterState));
|
assertThat(newState, equalTo(clusterState));
|
||||||
|
|
||||||
|
@ -113,7 +115,8 @@ public class TenShardsOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(), equalTo("node1"));
|
assertThat(clusterState.routingTable().index("test").shard(i).primaryShard().currentNodeId(), equalTo("node1"));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().size(), equalTo(1));
|
||||||
// backup shards are initializing as well, we make sure that they recover from primary *started* shards in the IndicesClusterStateService
|
// backup shards are initializing as well, we make sure that they
|
||||||
|
// recover from primary *started* shards in the IndicesClusterStateService
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).state(), equalTo(INITIALIZING));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(), equalTo("node2"));
|
assertThat(clusterState.routingTable().index("test").shard(i).replicaShards().get(0).currentNodeId(), equalTo("node2"));
|
||||||
}
|
}
|
||||||
|
@ -143,7 +146,8 @@ public class TenShardsOneReplicaRoutingTests extends ESAllocationTestCase {
|
||||||
assertThat(routingNodes.node("node2").numberOfShardsWithState(STARTED), equalTo(10));
|
assertThat(routingNodes.node("node2").numberOfShardsWithState(STARTED), equalTo(10));
|
||||||
|
|
||||||
logger.info("Add another node and perform rerouting");
|
logger.info("Add another node and perform rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
|
|
@ -157,7 +157,8 @@ public class ThrottlingAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().shardsWithState(UNASSIGNED).size(), equalTo(5));
|
assertThat(clusterState.routingTable().shardsWithState(UNASSIGNED).size(), equalTo(5));
|
||||||
|
|
||||||
logger.info("start another node, replicas should start being allocated");
|
logger.info("start another node, replicas should start being allocated");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(5));
|
||||||
|
@ -212,7 +213,8 @@ public class ThrottlingAllocationTests extends ESAllocationTestCase {
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.routingTable().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.routingTable().shardsWithState(INITIALIZING));
|
||||||
|
|
||||||
logger.info("start another 2 nodes, 5 shards should be relocating - at most 5 are allowed per node");
|
logger.info("start another 2 nodes, 5 shards should be relocating - at most 5 are allowed per node");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2")).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2")).add(newNode("node3"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(4));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(4));
|
||||||
|
@ -266,7 +268,8 @@ public class ThrottlingAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().shardsWithState(UNASSIGNED).size(), equalTo(2));
|
assertThat(clusterState.routingTable().shardsWithState(UNASSIGNED).size(), equalTo(2));
|
||||||
|
|
||||||
logger.info("start one more node, first non-primary should start being allocated");
|
logger.info("start one more node, first non-primary should start being allocated");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node2"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(1));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(1));
|
||||||
|
@ -282,7 +285,8 @@ public class ThrottlingAllocationTests extends ESAllocationTestCase {
|
||||||
assertEquals(clusterState.getRoutingNodes().getOutgoingRecoveries("node1"), 0);
|
assertEquals(clusterState.getRoutingNodes().getOutgoingRecoveries("node1"), 0);
|
||||||
|
|
||||||
logger.info("start one more node, initializing second non-primary");
|
logger.info("start one more node, initializing second non-primary");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(2));
|
assertThat(clusterState.routingTable().shardsWithState(STARTED).size(), equalTo(2));
|
||||||
|
@ -291,7 +295,8 @@ public class ThrottlingAllocationTests extends ESAllocationTestCase {
|
||||||
assertEquals(clusterState.getRoutingNodes().getOutgoingRecoveries("node1"), 1);
|
assertEquals(clusterState.getRoutingNodes().getOutgoingRecoveries("node1"), 1);
|
||||||
|
|
||||||
logger.info("start one more node");
|
logger.info("start one more node");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node4"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node4"))).build();
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
assertEquals(clusterState.getRoutingNodes().getOutgoingRecoveries("node1"), 1);
|
assertEquals(clusterState.getRoutingNodes().getOutgoingRecoveries("node1"), 1);
|
||||||
|
|
|
@ -43,7 +43,8 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
private final Logger logger = LogManager.getLogger(UpdateNumberOfReplicasTests.class);
|
private final Logger logger = LogManager.getLogger(UpdateNumberOfReplicasTests.class);
|
||||||
|
|
||||||
public void testUpdateNumberOfReplicas() {
|
public void testUpdateNumberOfReplicas() {
|
||||||
AllocationService strategy = createAllocationService(Settings.builder().put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
AllocationService strategy = createAllocationService(Settings.builder()
|
||||||
|
.put("cluster.routing.allocation.node_concurrent_recoveries", 10).build());
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
|
|
||||||
|
@ -55,7 +56,8 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
assertThat(initialRoutingTable.index("test").shards().size(), equalTo(1));
|
assertThat(initialRoutingTable.index("test").shards().size(), equalTo(1));
|
||||||
assertThat(initialRoutingTable.index("test").shard(0).size(), equalTo(2));
|
assertThat(initialRoutingTable.index("test").shard(0).size(), equalTo(2));
|
||||||
|
@ -67,7 +69,8 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
|
|
||||||
logger.info("Adding two nodes and performing rerouting");
|
logger.info("Adding two nodes and performing rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))).build();
|
||||||
|
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
||||||
|
@ -91,7 +94,8 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), equalTo(nodeHoldingReplica));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
equalTo(nodeHoldingReplica));
|
||||||
|
|
||||||
|
|
||||||
logger.info("add another replica");
|
logger.info("add another replica");
|
||||||
|
@ -110,11 +114,13 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), equalTo(nodeHoldingReplica));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
equalTo(nodeHoldingReplica));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(1).state(), equalTo(UNASSIGNED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(1).state(), equalTo(UNASSIGNED));
|
||||||
|
|
||||||
logger.info("Add another node and start the added replica");
|
logger.info("Add another node and start the added replica");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
clusterState = ClusterState.builder(clusterState)
|
||||||
|
.nodes(DiscoveryNodes.builder(clusterState.nodes()).add(newNode("node3"))).build();
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat(newState, not(equalTo(clusterState)));
|
assertThat(newState, not(equalTo(clusterState)));
|
||||||
clusterState = newState;
|
clusterState = newState;
|
||||||
|
@ -125,9 +131,11 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).get(0).currentNodeId(), equalTo(nodeHoldingReplica));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).get(0).currentNodeId(),
|
||||||
|
equalTo(nodeHoldingReplica));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(INITIALIZING).size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(INITIALIZING).get(0).currentNodeId(), equalTo("node3"));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(INITIALIZING).get(0).currentNodeId(),
|
||||||
|
equalTo("node3"));
|
||||||
|
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
newState = strategy.applyStartedShards(clusterState, routingNodes.shardsWithState(INITIALIZING));
|
newState = strategy.applyStartedShards(clusterState, routingNodes.shardsWithState(INITIALIZING));
|
||||||
|
@ -140,8 +148,10 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).size(), equalTo(2));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).size(), equalTo(2));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).get(0).currentNodeId(), anyOf(equalTo(nodeHoldingReplica), equalTo("node3")));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).get(0).currentNodeId(),
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).get(1).currentNodeId(), anyOf(equalTo(nodeHoldingReplica), equalTo("node3")));
|
anyOf(equalTo(nodeHoldingReplica), equalTo("node3")));
|
||||||
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShardsWithState(STARTED).get(1).currentNodeId(),
|
||||||
|
anyOf(equalTo(nodeHoldingReplica), equalTo("node3")));
|
||||||
|
|
||||||
logger.info("now remove a replica");
|
logger.info("now remove a replica");
|
||||||
routingNodes = clusterState.getRoutingNodes();
|
routingNodes = clusterState.getRoutingNodes();
|
||||||
|
@ -157,7 +167,8 @@ public class UpdateNumberOfReplicasTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
assertThat(clusterState.routingTable().index("test").shard(0).primaryShard().currentNodeId(), equalTo(nodeHoldingPrimary));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().size(), equalTo(1));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).state(), equalTo(STARTED));
|
||||||
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(), anyOf(equalTo(nodeHoldingReplica), equalTo("node3")));
|
assertThat(clusterState.routingTable().index("test").shard(0).replicaShards().get(0).currentNodeId(),
|
||||||
|
anyOf(equalTo(nodeHoldingReplica), equalTo("node3")));
|
||||||
|
|
||||||
logger.info("do a reroute, should remain the same");
|
logger.info("do a reroute, should remain the same");
|
||||||
newState = strategy.reroute(clusterState, "reroute");
|
newState = strategy.reroute(clusterState, "reroute");
|
||||||
|
|
|
@ -70,7 +70,8 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
final Index index = metaData.index("test").getIndex();
|
final Index index = metaData.index("test").getIndex();
|
||||||
|
|
||||||
ShardRouting test_0 = ShardRouting.newUnassigned(new ShardId(index, 0), true, EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_0 = ShardRouting.newUnassigned(new ShardId(index, 0), true, EmptyStoreRecoverySource.INSTANCE,
|
||||||
|
new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
DiscoveryNode node_0 = new DiscoveryNode("node_0", buildNewFakeTransportAddress(), Collections.emptyMap(),
|
DiscoveryNode node_0 = new DiscoveryNode("node_0", buildNewFakeTransportAddress(), Collections.emptyMap(),
|
||||||
new HashSet<>(Arrays.asList(DiscoveryNode.Role.values())), Version.CURRENT);
|
new HashSet<>(Arrays.asList(DiscoveryNode.Role.values())), Version.CURRENT);
|
||||||
DiscoveryNode node_1 = new DiscoveryNode("node_1", buildNewFakeTransportAddress(), Collections.emptyMap(),
|
DiscoveryNode node_1 = new DiscoveryNode("node_1", buildNewFakeTransportAddress(), Collections.emptyMap(),
|
||||||
|
@ -94,22 +95,25 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
leastAvailableUsages.put("node_1", new DiskUsage("node_1", "node_1", "_na_", 100, 0)); // all full
|
leastAvailableUsages.put("node_1", new DiskUsage("node_1", "node_1", "_na_", 100, 0)); // all full
|
||||||
|
|
||||||
ImmutableOpenMap.Builder<String, DiskUsage> mostAvailableUsage = ImmutableOpenMap.builder();
|
ImmutableOpenMap.Builder<String, DiskUsage> mostAvailableUsage = ImmutableOpenMap.builder();
|
||||||
mostAvailableUsage.put("node_0", new DiskUsage("node_0", "node_0", "_na_", 100, randomIntBetween(20, 100))); // 20 - 99 percent since after allocation there must be at least 10% left and shard is 10byte
|
// 20 - 99 percent since after allocation there must be at least 10% left and shard is 10byte
|
||||||
mostAvailableUsage.put("node_1", new DiskUsage("node_1", "node_1", "_na_", 100, randomIntBetween(0, 10))); // this is weird and smells like a bug! it should be up to 20%?
|
mostAvailableUsage.put("node_0", new DiskUsage("node_0", "node_0", "_na_", 100, randomIntBetween(20, 100)));
|
||||||
|
// this is weird and smells like a bug! it should be up to 20%?
|
||||||
|
mostAvailableUsage.put("node_1", new DiskUsage("node_1", "node_1", "_na_", 100, randomIntBetween(0, 10)));
|
||||||
|
|
||||||
ImmutableOpenMap.Builder<String, Long> shardSizes = ImmutableOpenMap.builder();
|
ImmutableOpenMap.Builder<String, Long> shardSizes = ImmutableOpenMap.builder();
|
||||||
shardSizes.put("[test][0][p]", 10L); // 10 bytes
|
shardSizes.put("[test][0][p]", 10L); // 10 bytes
|
||||||
final ClusterInfo clusterInfo = new ClusterInfo(leastAvailableUsages.build(), mostAvailableUsage.build(), shardSizes.build(), ImmutableOpenMap.of());
|
final ClusterInfo clusterInfo = new ClusterInfo(leastAvailableUsages.build(),
|
||||||
RoutingAllocation allocation = new RoutingAllocation(new AllocationDeciders(Settings.EMPTY, Collections.singleton(decider)), clusterState.getRoutingNodes(), clusterState, clusterInfo, System.nanoTime());
|
mostAvailableUsage.build(), shardSizes.build(), ImmutableOpenMap.of());
|
||||||
|
RoutingAllocation allocation = new RoutingAllocation(new AllocationDeciders(Settings.EMPTY, Collections.singleton(decider)),
|
||||||
|
clusterState.getRoutingNodes(), clusterState, clusterInfo, System.nanoTime());
|
||||||
allocation.debugDecision(true);
|
allocation.debugDecision(true);
|
||||||
Decision decision = decider.canAllocate(test_0, new RoutingNode("node_0", node_0), allocation);
|
Decision decision = decider.canAllocate(test_0, new RoutingNode("node_0", node_0), allocation);
|
||||||
assertEquals(mostAvailableUsage.toString(), Decision.Type.YES, decision.type());
|
assertEquals(mostAvailableUsage.toString(), Decision.Type.YES, decision.type());
|
||||||
assertThat(((Decision.Single) decision).getExplanation(), containsString("enough disk for shard on node"));
|
assertThat(((Decision.Single) decision).getExplanation(), containsString("enough disk for shard on node"));
|
||||||
decision = decider.canAllocate(test_0, new RoutingNode("node_1", node_1), allocation);
|
decision = decider.canAllocate(test_0, new RoutingNode("node_1", node_1), allocation);
|
||||||
assertEquals(mostAvailableUsage.toString(), Decision.Type.NO, decision.type());
|
assertEquals(mostAvailableUsage.toString(), Decision.Type.NO, decision.type());
|
||||||
assertThat(((Decision.Single) decision).getExplanation(), containsString(
|
assertThat(((Decision.Single) decision).getExplanation(), containsString("the node is above the high watermark cluster " +
|
||||||
"the node is above the high watermark cluster setting [cluster.routing.allocation.disk.watermark.high=90%], using more " +
|
"setting [cluster.routing.allocation.disk.watermark.high=90%], using more disk space than the maximum allowed [90.0%]"));
|
||||||
"disk space than the maximum allowed [90.0%]"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCannotAllocateDueToLackOfDiskResources() {
|
public void testCannotAllocateDueToLackOfDiskResources() {
|
||||||
|
@ -153,7 +157,8 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
// way bigger than available space
|
// way bigger than available space
|
||||||
final long shardSize = randomIntBetween(110, 1000);
|
final long shardSize = randomIntBetween(110, 1000);
|
||||||
shardSizes.put("[test][0][p]", shardSize);
|
shardSizes.put("[test][0][p]", shardSize);
|
||||||
ClusterInfo clusterInfo = new ClusterInfo(leastAvailableUsages.build(), mostAvailableUsage.build(), shardSizes.build(), ImmutableOpenMap.of());
|
ClusterInfo clusterInfo = new ClusterInfo(leastAvailableUsages.build(), mostAvailableUsage.build(),
|
||||||
|
shardSizes.build(), ImmutableOpenMap.of());
|
||||||
RoutingAllocation allocation = new RoutingAllocation(new AllocationDeciders(Settings.EMPTY, Collections.singleton(decider)),
|
RoutingAllocation allocation = new RoutingAllocation(new AllocationDeciders(Settings.EMPTY, Collections.singleton(decider)),
|
||||||
clusterState.getRoutingNodes(), clusterState, clusterInfo, System.nanoTime());
|
clusterState.getRoutingNodes(), clusterState, clusterInfo, System.nanoTime());
|
||||||
allocation.debugDecision(true);
|
allocation.debugDecision(true);
|
||||||
|
@ -182,22 +187,26 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
.build();
|
.build();
|
||||||
final IndexMetaData indexMetaData = metaData.index("test");
|
final IndexMetaData indexMetaData = metaData.index("test");
|
||||||
|
|
||||||
ShardRouting test_0 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 0), true, EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_0 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 0), true,
|
||||||
|
EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_0 = ShardRoutingHelper.initialize(test_0, node_0.getId());
|
test_0 = ShardRoutingHelper.initialize(test_0, node_0.getId());
|
||||||
test_0 = ShardRoutingHelper.moveToStarted(test_0);
|
test_0 = ShardRoutingHelper.moveToStarted(test_0);
|
||||||
shardRoutingMap.put(test_0, "/node0/least");
|
shardRoutingMap.put(test_0, "/node0/least");
|
||||||
|
|
||||||
ShardRouting test_1 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 1), true, EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_1 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 1), true,
|
||||||
|
EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_1 = ShardRoutingHelper.initialize(test_1, node_1.getId());
|
test_1 = ShardRoutingHelper.initialize(test_1, node_1.getId());
|
||||||
test_1 = ShardRoutingHelper.moveToStarted(test_1);
|
test_1 = ShardRoutingHelper.moveToStarted(test_1);
|
||||||
shardRoutingMap.put(test_1, "/node1/least");
|
shardRoutingMap.put(test_1, "/node1/least");
|
||||||
|
|
||||||
ShardRouting test_2 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 2), true, EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_2 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 2), true,
|
||||||
|
EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_2 = ShardRoutingHelper.initialize(test_2, node_1.getId());
|
test_2 = ShardRoutingHelper.initialize(test_2, node_1.getId());
|
||||||
test_2 = ShardRoutingHelper.moveToStarted(test_2);
|
test_2 = ShardRoutingHelper.moveToStarted(test_2);
|
||||||
shardRoutingMap.put(test_2, "/node1/most");
|
shardRoutingMap.put(test_2, "/node1/most");
|
||||||
|
|
||||||
ShardRouting test_3 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 3), true, EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_3 = ShardRouting.newUnassigned(new ShardId(indexMetaData.getIndex(), 3), true,
|
||||||
|
EmptyStoreRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_3 = ShardRoutingHelper.initialize(test_3, node_1.getId());
|
test_3 = ShardRoutingHelper.initialize(test_3, node_1.getId());
|
||||||
test_3 = ShardRoutingHelper.moveToStarted(test_3);
|
test_3 = ShardRoutingHelper.moveToStarted(test_3);
|
||||||
// Intentionally not in the shardRoutingMap. We want to test what happens when we don't know where it is.
|
// Intentionally not in the shardRoutingMap. We want to test what happens when we don't know where it is.
|
||||||
|
@ -206,7 +215,8 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
.addAsNew(indexMetaData)
|
.addAsNew(indexMetaData)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes");
|
logger.info("--> adding two nodes");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -228,8 +238,10 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
shardSizes.put("[test][1][p]", 10L);
|
shardSizes.put("[test][1][p]", 10L);
|
||||||
shardSizes.put("[test][2][p]", 10L);
|
shardSizes.put("[test][2][p]", 10L);
|
||||||
|
|
||||||
final ClusterInfo clusterInfo = new ClusterInfo(leastAvailableUsages.build(), mostAvailableUsage.build(), shardSizes.build(), shardRoutingMap.build());
|
final ClusterInfo clusterInfo = new ClusterInfo(leastAvailableUsages.build(), mostAvailableUsage.build(),
|
||||||
RoutingAllocation allocation = new RoutingAllocation(new AllocationDeciders(Settings.EMPTY, Collections.singleton(decider)), clusterState.getRoutingNodes(), clusterState, clusterInfo, System.nanoTime());
|
shardSizes.build(), shardRoutingMap.build());
|
||||||
|
RoutingAllocation allocation = new RoutingAllocation(new AllocationDeciders(Settings.EMPTY, Collections.singleton(decider)),
|
||||||
|
clusterState.getRoutingNodes(), clusterState, clusterInfo, System.nanoTime());
|
||||||
allocation.debugDecision(true);
|
allocation.debugDecision(true);
|
||||||
Decision decision = decider.canRemain(test_0, new RoutingNode("node_0", node_0), allocation);
|
Decision decision = decider.canRemain(test_0, new RoutingNode("node_0", node_0), allocation);
|
||||||
assertEquals(Decision.Type.YES, decision.type());
|
assertEquals(Decision.Type.YES, decision.type());
|
||||||
|
@ -273,28 +285,33 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
shardSizes.put("[other][0][p]", 10000L);
|
shardSizes.put("[other][0][p]", 10000L);
|
||||||
ClusterInfo info = new DevNullClusterInfo(ImmutableOpenMap.of(), ImmutableOpenMap.of(), shardSizes.build());
|
ClusterInfo info = new DevNullClusterInfo(ImmutableOpenMap.of(), ImmutableOpenMap.of(), shardSizes.build());
|
||||||
MetaData.Builder metaBuilder = MetaData.builder();
|
MetaData.Builder metaBuilder = MetaData.builder();
|
||||||
metaBuilder.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT).put("index.uuid", "1234")).numberOfShards(3).numberOfReplicas(1));
|
metaBuilder.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT)
|
||||||
metaBuilder.put(IndexMetaData.builder("other").settings(settings(Version.CURRENT).put("index.uuid", "5678")).numberOfShards(1).numberOfReplicas(1));
|
.put("index.uuid", "1234")).numberOfShards(3).numberOfReplicas(1));
|
||||||
|
metaBuilder.put(IndexMetaData.builder("other").settings(settings(Version.CURRENT)
|
||||||
|
.put("index.uuid", "5678")).numberOfShards(1).numberOfReplicas(1));
|
||||||
MetaData metaData = metaBuilder.build();
|
MetaData metaData = metaBuilder.build();
|
||||||
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
RoutingTable.Builder routingTableBuilder = RoutingTable.builder();
|
||||||
routingTableBuilder.addAsNew(metaData.index("test"));
|
routingTableBuilder.addAsNew(metaData.index("test"));
|
||||||
routingTableBuilder.addAsNew(metaData.index("other"));
|
routingTableBuilder.addAsNew(metaData.index("other"));
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
.metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTableBuilder.build()).build();
|
||||||
RoutingAllocation allocation = new RoutingAllocation(null, null, clusterState, info, 0);
|
RoutingAllocation allocation = new RoutingAllocation(null, null, clusterState, info, 0);
|
||||||
|
|
||||||
final Index index = new Index("test", "1234");
|
final Index index = new Index("test", "1234");
|
||||||
ShardRouting test_0 = ShardRouting.newUnassigned(new ShardId(index, 0), false, PeerRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_0 = ShardRouting.newUnassigned(new ShardId(index, 0), false, PeerRecoverySource.INSTANCE,
|
||||||
|
new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_0 = ShardRoutingHelper.initialize(test_0, "node1");
|
test_0 = ShardRoutingHelper.initialize(test_0, "node1");
|
||||||
test_0 = ShardRoutingHelper.moveToStarted(test_0);
|
test_0 = ShardRoutingHelper.moveToStarted(test_0);
|
||||||
test_0 = ShardRoutingHelper.relocate(test_0, "node2");
|
test_0 = ShardRoutingHelper.relocate(test_0, "node2");
|
||||||
|
|
||||||
ShardRouting test_1 = ShardRouting.newUnassigned(new ShardId(index, 1), false, PeerRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_1 = ShardRouting.newUnassigned(new ShardId(index, 1), false, PeerRecoverySource.INSTANCE,
|
||||||
|
new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_1 = ShardRoutingHelper.initialize(test_1, "node2");
|
test_1 = ShardRoutingHelper.initialize(test_1, "node2");
|
||||||
test_1 = ShardRoutingHelper.moveToStarted(test_1);
|
test_1 = ShardRoutingHelper.moveToStarted(test_1);
|
||||||
test_1 = ShardRoutingHelper.relocate(test_1, "node1");
|
test_1 = ShardRoutingHelper.relocate(test_1, "node1");
|
||||||
|
|
||||||
ShardRouting test_2 = ShardRouting.newUnassigned(new ShardId(index, 2), false, PeerRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_2 = ShardRouting.newUnassigned(new ShardId(index, 2), false, PeerRecoverySource.INSTANCE,
|
||||||
|
new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_2 = ShardRoutingHelper.initialize(test_2, "node1");
|
test_2 = ShardRoutingHelper.initialize(test_2, "node1");
|
||||||
test_2 = ShardRoutingHelper.moveToStarted(test_2);
|
test_2 = ShardRoutingHelper.moveToStarted(test_2);
|
||||||
|
|
||||||
|
@ -309,19 +326,21 @@ public class DiskThresholdDeciderUnitTests extends ESAllocationTestCase {
|
||||||
assertEquals(0L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, true, "/dev/some/other/dev"));
|
assertEquals(0L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, true, "/dev/some/other/dev"));
|
||||||
assertEquals(0L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, true, "/dev/some/other/dev"));
|
assertEquals(0L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, true, "/dev/some/other/dev"));
|
||||||
|
|
||||||
ShardRouting test_3 = ShardRouting.newUnassigned(new ShardId(index, 3), false, PeerRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting test_3 = ShardRouting.newUnassigned(new ShardId(index, 3), false, PeerRecoverySource.INSTANCE,
|
||||||
|
new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
test_3 = ShardRoutingHelper.initialize(test_3, "node1");
|
test_3 = ShardRoutingHelper.initialize(test_3, "node1");
|
||||||
test_3 = ShardRoutingHelper.moveToStarted(test_3);
|
test_3 = ShardRoutingHelper.moveToStarted(test_3);
|
||||||
assertEquals(0L, DiskThresholdDecider.getExpectedShardSize(test_3, allocation, 0));
|
assertEquals(0L, DiskThresholdDecider.getExpectedShardSize(test_3, allocation, 0));
|
||||||
|
|
||||||
|
|
||||||
ShardRouting other_0 = ShardRouting.newUnassigned(new ShardId("other", "5678", 0), randomBoolean(), PeerRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
ShardRouting other_0 = ShardRouting.newUnassigned(new ShardId("other", "5678", 0), randomBoolean(),
|
||||||
|
PeerRecoverySource.INSTANCE, new UnassignedInfo(UnassignedInfo.Reason.INDEX_CREATED, "foo"));
|
||||||
other_0 = ShardRoutingHelper.initialize(other_0, "node2");
|
other_0 = ShardRoutingHelper.initialize(other_0, "node2");
|
||||||
other_0 = ShardRoutingHelper.moveToStarted(other_0);
|
other_0 = ShardRoutingHelper.moveToStarted(other_0);
|
||||||
other_0 = ShardRoutingHelper.relocate(other_0, "node1");
|
other_0 = ShardRoutingHelper.relocate(other_0, "node1");
|
||||||
|
|
||||||
node = new RoutingNode("node1", new DiscoveryNode("node1", buildNewFakeTransportAddress(),
|
node = new RoutingNode("node1", new DiscoveryNode("node1", buildNewFakeTransportAddress(), emptyMap(), emptySet(),
|
||||||
emptyMap(), emptySet(), Version.CURRENT), test_0, test_1.getTargetRelocatingShard(), test_2, other_0.getTargetRelocatingShard());
|
Version.CURRENT), test_0, test_1.getTargetRelocatingShard(), test_2, other_0.getTargetRelocatingShard());
|
||||||
if (other_0.primary()) {
|
if (other_0.primary()) {
|
||||||
assertEquals(10100L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, false, "/dev/null"));
|
assertEquals(10100L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, false, "/dev/null"));
|
||||||
assertEquals(10090L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, true, "/dev/null"));
|
assertEquals(10090L, DiskThresholdDecider.sizeOfRelocatingShards(node, allocation, true, "/dev/null"));
|
||||||
|
|
|
@ -67,7 +67,8 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes and do rerouting");
|
logger.info("--> adding two nodes and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -95,7 +96,8 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes do rerouting");
|
logger.info("--> adding two nodes do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -107,7 +109,8 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(1));
|
||||||
|
|
||||||
logger.info("--> start the shards (primaries)");
|
logger.info("--> start the shards (primaries)");
|
||||||
routingTable = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING)).routingTable();
|
routingTable = strategy.applyStartedShards(clusterState,
|
||||||
|
clusterState.getRoutingNodes().shardsWithState(INITIALIZING)).routingTable();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
clusterState = ClusterState.builder(clusterState).routingTable(routingTable).build();
|
||||||
|
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(0));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(INITIALIZING).size(), equalTo(0));
|
||||||
|
@ -129,7 +132,8 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("enabled"))
|
.addAsNew(metaData.index("enabled"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding two nodes and do rerouting");
|
logger.info("--> adding two nodes and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -152,18 +156,24 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
final boolean useClusterSetting = randomBoolean();
|
final boolean useClusterSetting = randomBoolean();
|
||||||
final Rebalance allowedOnes = RandomPicks.randomFrom(random(), EnumSet.of(Rebalance.PRIMARIES, Rebalance.REPLICAS, Rebalance.ALL));
|
final Rebalance allowedOnes = RandomPicks.randomFrom(random(), EnumSet.of(Rebalance.PRIMARIES, Rebalance.REPLICAS, Rebalance.ALL));
|
||||||
Settings build = Settings.builder()
|
Settings build = Settings.builder()
|
||||||
.put(CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), useClusterSetting ? Rebalance.NONE: RandomPicks.randomFrom(random(), Rebalance.values())) // index settings override cluster settings
|
.put(CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey(),
|
||||||
|
// index settings override cluster settings
|
||||||
|
useClusterSetting ? Rebalance.NONE: RandomPicks.randomFrom(random(), Rebalance.values()))
|
||||||
.put(ConcurrentRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_CLUSTER_CONCURRENT_REBALANCE_SETTING.getKey(), 3)
|
.put(ConcurrentRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_CLUSTER_CONCURRENT_REBALANCE_SETTING.getKey(), 3)
|
||||||
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_OUTGOING_RECOVERIES_SETTING.getKey(), 10)
|
.put(ThrottlingAllocationDecider.CLUSTER_ROUTING_ALLOCATION_NODE_CONCURRENT_OUTGOING_RECOVERIES_SETTING.getKey(), 10)
|
||||||
.build();
|
.build();
|
||||||
ClusterSettings clusterSettings = new ClusterSettings(build, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS);
|
ClusterSettings clusterSettings = new ClusterSettings(build, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS);
|
||||||
AllocationService strategy = createAllocationService(build, clusterSettings, random());
|
AllocationService strategy = createAllocationService(build, clusterSettings, random());
|
||||||
Settings indexSettings = useClusterSetting ? Settings.EMPTY : Settings.builder().put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), Rebalance.NONE).build();
|
Settings indexSettings = useClusterSetting ? Settings.EMPTY : Settings.builder()
|
||||||
|
.put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), Rebalance.NONE).build();
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder()
|
||||||
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT).put(indexSettings)).numberOfShards(3).numberOfReplicas(1))
|
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT).put(indexSettings))
|
||||||
.put(IndexMetaData.builder("always_disabled").settings(settings(Version.CURRENT).put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), Rebalance.NONE)).numberOfShards(1).numberOfReplicas(1))
|
.numberOfShards(3).numberOfReplicas(1))
|
||||||
|
.put(IndexMetaData.builder("always_disabled").settings(settings(Version.CURRENT)
|
||||||
|
.put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), Rebalance.NONE))
|
||||||
|
.numberOfShards(1).numberOfReplicas(1))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder()
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
|
@ -171,7 +181,8 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("always_disabled"))
|
.addAsNew(metaData.index("always_disabled"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding one nodes and do rerouting");
|
logger.info("--> adding one nodes and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -200,21 +211,23 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
assertThat(clusterState.getRoutingNodes().shardsWithState(RELOCATING).size(), equalTo(0));
|
assertThat(clusterState.getRoutingNodes().shardsWithState(RELOCATING).size(), equalTo(0));
|
||||||
|
|
||||||
if (useClusterSetting) {
|
if (useClusterSetting) {
|
||||||
clusterState = ClusterState.builder(clusterState).metaData(MetaData.builder(clusterState.metaData()).transientSettings(Settings.builder()
|
clusterState = ClusterState.builder(clusterState).metaData(MetaData.builder(clusterState.metaData())
|
||||||
.put(CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), allowedOnes)
|
.transientSettings(Settings.builder().put(CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), allowedOnes)
|
||||||
.build())).build();
|
.build())).build();
|
||||||
} else {
|
} else {
|
||||||
IndexMetaData meta = clusterState.getMetaData().index("test");
|
IndexMetaData meta = clusterState.getMetaData().index("test");
|
||||||
IndexMetaData meta1 = clusterState.getMetaData().index("always_disabled");
|
IndexMetaData meta1 = clusterState.getMetaData().index("always_disabled");
|
||||||
clusterState = ClusterState.builder(clusterState).metaData(MetaData.builder(clusterState.metaData()).removeAllIndices().put(IndexMetaData.builder(meta1))
|
clusterState = ClusterState.builder(clusterState).metaData(MetaData.builder(clusterState.metaData()).removeAllIndices()
|
||||||
.put(IndexMetaData.builder(meta).settings(Settings.builder().put(meta.getSettings()).put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), allowedOnes).build())))
|
.put(IndexMetaData.builder(meta1)).put(IndexMetaData.builder(meta).settings(Settings.builder().put(meta.getSettings())
|
||||||
.build();
|
.put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), allowedOnes).build()))).build();
|
||||||
|
|
||||||
}
|
}
|
||||||
clusterSettings.applySettings(clusterState.metaData().settings());
|
clusterSettings.applySettings(clusterState.metaData().settings());
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat("expected 6 shards to be started 2 to relocate useClusterSettings: " + useClusterSetting, clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(6));
|
assertThat("expected 6 shards to be started 2 to relocate useClusterSettings: " + useClusterSetting,
|
||||||
assertThat("expected 2 shards to relocate useClusterSettings: " + useClusterSetting, clusterState.getRoutingNodes().shardsWithState(RELOCATING).size(), equalTo(2));
|
clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(6));
|
||||||
|
assertThat("expected 2 shards to relocate useClusterSettings: " + useClusterSetting,
|
||||||
|
clusterState.getRoutingNodes().shardsWithState(RELOCATING).size(), equalTo(2));
|
||||||
List<ShardRouting> mutableShardRoutings = clusterState.getRoutingNodes().shardsWithState(RELOCATING);
|
List<ShardRouting> mutableShardRoutings = clusterState.getRoutingNodes().shardsWithState(RELOCATING);
|
||||||
switch (allowedOnes) {
|
switch (allowedOnes) {
|
||||||
case PRIMARIES:
|
case PRIMARIES:
|
||||||
|
@ -246,23 +259,26 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
public void testEnableClusterBalanceNoReplicas() {
|
public void testEnableClusterBalanceNoReplicas() {
|
||||||
final boolean useClusterSetting = randomBoolean();
|
final boolean useClusterSetting = randomBoolean();
|
||||||
Settings build = Settings.builder()
|
Settings build = Settings.builder()
|
||||||
.put(CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), useClusterSetting ? Rebalance.NONE: RandomPicks.randomFrom(random(), Rebalance.values())) // index settings override cluster settings
|
.put(CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey(),
|
||||||
|
// index settings override cluster settings
|
||||||
|
useClusterSetting ? Rebalance.NONE: RandomPicks.randomFrom(random(), Rebalance.values()))
|
||||||
.put(ConcurrentRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_CLUSTER_CONCURRENT_REBALANCE_SETTING.getKey(), 3)
|
.put(ConcurrentRebalanceAllocationDecider.CLUSTER_ROUTING_ALLOCATION_CLUSTER_CONCURRENT_REBALANCE_SETTING.getKey(), 3)
|
||||||
.build();
|
.build();
|
||||||
ClusterSettings clusterSettings = new ClusterSettings(build, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS);
|
ClusterSettings clusterSettings = new ClusterSettings(build, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS);
|
||||||
AllocationService strategy = createAllocationService(build, clusterSettings, random());
|
AllocationService strategy = createAllocationService(build, clusterSettings, random());
|
||||||
Settings indexSettings = useClusterSetting ? Settings.EMPTY : Settings.builder().put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), Rebalance.NONE).build();
|
Settings indexSettings = useClusterSetting ? Settings.EMPTY : Settings.builder()
|
||||||
|
.put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), Rebalance.NONE).build();
|
||||||
|
|
||||||
logger.info("Building initial routing table");
|
logger.info("Building initial routing table");
|
||||||
MetaData metaData = MetaData.builder()
|
MetaData metaData = MetaData.builder().put(IndexMetaData.builder("test")
|
||||||
.put(IndexMetaData.builder("test").settings(settings(Version.CURRENT).put(indexSettings)).numberOfShards(6).numberOfReplicas(0))
|
.settings(settings(Version.CURRENT).put(indexSettings)).numberOfShards(6).numberOfReplicas(0)).build();
|
||||||
.build();
|
|
||||||
|
|
||||||
RoutingTable initialRoutingTable = RoutingTable.builder()
|
RoutingTable initialRoutingTable = RoutingTable.builder()
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
ClusterState clusterState = ClusterState.builder(org.elasticsearch.cluster.ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(initialRoutingTable).build();
|
||||||
|
|
||||||
logger.info("--> adding one nodes and do rerouting");
|
logger.info("--> adding one nodes and do rerouting");
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
|
@ -293,12 +309,16 @@ public class EnableAllocationTests extends ESAllocationTestCase {
|
||||||
} else {
|
} else {
|
||||||
IndexMetaData meta = clusterState.getMetaData().index("test");
|
IndexMetaData meta = clusterState.getMetaData().index("test");
|
||||||
clusterState = ClusterState.builder(clusterState).metaData(MetaData.builder(metaData).removeAllIndices()
|
clusterState = ClusterState.builder(clusterState).metaData(MetaData.builder(metaData).removeAllIndices()
|
||||||
.put(IndexMetaData.builder(meta).settings(Settings.builder().put(meta.getSettings()).put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(), randomBoolean() ? Rebalance.PRIMARIES : Rebalance.ALL).build()))).build();
|
.put(IndexMetaData.builder(meta).settings(Settings.builder().put(meta.getSettings())
|
||||||
|
.put(EnableAllocationDecider.INDEX_ROUTING_REBALANCE_ENABLE_SETTING.getKey(),
|
||||||
|
randomBoolean() ? Rebalance.PRIMARIES : Rebalance.ALL).build()))).build();
|
||||||
}
|
}
|
||||||
clusterSettings.applySettings(clusterState.metaData().settings());
|
clusterSettings.applySettings(clusterState.metaData().settings());
|
||||||
clusterState = strategy.reroute(clusterState, "reroute");
|
clusterState = strategy.reroute(clusterState, "reroute");
|
||||||
assertThat("expected 4 primaries to be started and 2 to relocate useClusterSettings: " + useClusterSetting, clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(4));
|
assertThat("expected 4 primaries to be started and 2 to relocate useClusterSettings: " +
|
||||||
assertThat("expected 2 primaries to relocate useClusterSettings: " + useClusterSetting, clusterState.getRoutingNodes().shardsWithState(RELOCATING).size(), equalTo(2));
|
useClusterSetting, clusterState.getRoutingNodes().shardsWithState(STARTED).size(), equalTo(4));
|
||||||
|
assertThat("expected 2 primaries to relocate useClusterSettings: " + useClusterSetting,
|
||||||
|
clusterState.getRoutingNodes().shardsWithState(RELOCATING).size(), equalTo(2));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -63,9 +63,11 @@ public class ClusterSerializationTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
DiscoveryNodes nodes = DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2")).add(newNode("node3")).localNodeId("node1").masterNodeId("node2").build();
|
DiscoveryNodes nodes = DiscoveryNodes.builder().add(newNode("node1")).add(newNode("node2"))
|
||||||
|
.add(newNode("node3")).localNodeId("node1").masterNodeId("node2").build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(new ClusterName("clusterName1")).nodes(nodes).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(new ClusterName("clusterName1"))
|
||||||
|
.nodes(nodes).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
AllocationService strategy = createAllocationService();
|
AllocationService strategy = createAllocationService();
|
||||||
clusterState = ClusterState.builder(clusterState).routingTable(strategy.reroute(clusterState, "reroute").routingTable()).build();
|
clusterState = ClusterState.builder(clusterState).routingTable(strategy.reroute(clusterState, "reroute").routingTable()).build();
|
||||||
|
|
|
@ -196,11 +196,12 @@ public class DiffableTests extends ESTestCase {
|
||||||
*/
|
*/
|
||||||
public abstract class MapDriver<T, V> {
|
public abstract class MapDriver<T, V> {
|
||||||
protected final Set<Integer> keys = randomPositiveIntSet();
|
protected final Set<Integer> keys = randomPositiveIntSet();
|
||||||
protected final Set<Integer> keysToRemove = new HashSet<>(randomSubsetOf(randomInt(keys.size()), keys.toArray(new Integer[keys.size()])));
|
protected final Set<Integer> keysToRemove = new HashSet<>(randomSubsetOf(randomInt(keys.size()), keys.toArray(new Integer[0])));
|
||||||
protected final Set<Integer> keysThatAreNotRemoved = Sets.difference(keys, keysToRemove);
|
protected final Set<Integer> keysThatAreNotRemoved = Sets.difference(keys, keysToRemove);
|
||||||
protected final Set<Integer> keysToOverride = new HashSet<>(randomSubsetOf(randomInt(keysThatAreNotRemoved.size()),
|
protected final Set<Integer> keysToOverride = new HashSet<>(randomSubsetOf(randomInt(keysThatAreNotRemoved.size()),
|
||||||
keysThatAreNotRemoved.toArray(new Integer[keysThatAreNotRemoved.size()])));
|
keysThatAreNotRemoved.toArray(new Integer[keysThatAreNotRemoved.size()])));
|
||||||
protected final Set<Integer> keysToAdd = Sets.difference(randomPositiveIntSet(), keys); // make sure keysToAdd does not contain elements in keys
|
// make sure keysToAdd does not contain elements in keys
|
||||||
|
protected final Set<Integer> keysToAdd = Sets.difference(randomPositiveIntSet(), keys);
|
||||||
protected final Set<Integer> keysUnchanged = Sets.difference(keysThatAreNotRemoved, keysToOverride);
|
protected final Set<Integer> keysUnchanged = Sets.difference(keysThatAreNotRemoved, keysToOverride);
|
||||||
|
|
||||||
protected final DiffableUtils.KeySerializer<Integer> keySerializer = randomBoolean()
|
protected final DiffableUtils.KeySerializer<Integer> keySerializer = randomBoolean()
|
||||||
|
|
|
@ -87,7 +87,8 @@ public class ClusterSettingsIT extends ESIntegTestCase {
|
||||||
|
|
||||||
response = client().admin().cluster()
|
response = client().admin().cluster()
|
||||||
.prepareUpdateSettings()
|
.prepareUpdateSettings()
|
||||||
.setTransientSettings(Settings.builder().putNull((randomBoolean() ? "discovery.zen.*" : "*")).put(DiscoverySettings.PUBLISH_TIMEOUT_SETTING.getKey(), "2s"))
|
.setTransientSettings(Settings.builder().putNull((randomBoolean() ? "discovery.zen.*" : "*"))
|
||||||
|
.put(DiscoverySettings.PUBLISH_TIMEOUT_SETTING.getKey(), "2s"))
|
||||||
.get();
|
.get();
|
||||||
assertEquals(response.getTransientSettings().get(DiscoverySettings.PUBLISH_TIMEOUT_SETTING.getKey()), "2s");
|
assertEquals(response.getTransientSettings().get(DiscoverySettings.PUBLISH_TIMEOUT_SETTING.getKey()), "2s");
|
||||||
assertNull(response.getTransientSettings().getAsBoolean(DiscoverySettings.PUBLISH_DIFF_ENABLE_SETTING.getKey(), null));
|
assertNull(response.getTransientSettings().getAsBoolean(DiscoverySettings.PUBLISH_DIFF_ENABLE_SETTING.getKey(), null));
|
||||||
|
@ -274,7 +275,8 @@ public class ClusterSettingsIT extends ESIntegTestCase {
|
||||||
.get();
|
.get();
|
||||||
fail("bogus value");
|
fail("bogus value");
|
||||||
} catch (IllegalArgumentException ex) {
|
} catch (IllegalArgumentException ex) {
|
||||||
assertEquals(ex.getMessage(), "failed to parse setting [discovery.zen.publish_timeout] with value [whatever] as a time value: unit is missing or unrecognized");
|
assertEquals(ex.getMessage(), "failed to parse setting [discovery.zen.publish_timeout] with value [whatever]" +
|
||||||
|
" as a time value: unit is missing or unrecognized");
|
||||||
}
|
}
|
||||||
|
|
||||||
assertThat(discoverySettings.getPublishTimeout().seconds(), equalTo(1L));
|
assertThat(discoverySettings.getPublishTimeout().seconds(), equalTo(1L));
|
||||||
|
@ -292,7 +294,9 @@ public class ClusterSettingsIT extends ESIntegTestCase {
|
||||||
assertThat(discoverySettings.getPublishTimeout().seconds(), equalTo(1L));
|
assertThat(discoverySettings.getPublishTimeout().seconds(), equalTo(1L));
|
||||||
}
|
}
|
||||||
|
|
||||||
private DiscoverySettings getDiscoverySettings() {return ((ZenDiscovery) internalCluster().getInstance(Discovery.class)).getDiscoverySettings();}
|
private DiscoverySettings getDiscoverySettings() {
|
||||||
|
return ((ZenDiscovery) internalCluster().getInstance(Discovery.class)).getDiscoverySettings();
|
||||||
|
}
|
||||||
|
|
||||||
public void testClusterUpdateSettingsWithBlocks() {
|
public void testClusterUpdateSettingsWithBlocks() {
|
||||||
String key1 = "cluster.routing.allocation.enable";
|
String key1 = "cluster.routing.allocation.enable";
|
||||||
|
@ -344,7 +348,8 @@ public class ClusterSettingsIT extends ESIntegTestCase {
|
||||||
assertAcked(prepareCreate("test"));
|
assertAcked(prepareCreate("test"));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
client().admin().indices().prepareUpdateSettings("test").setSettings(Settings.builder().put("index.refresh_interval", "10")).execute().actionGet();
|
client().admin().indices().prepareUpdateSettings("test")
|
||||||
|
.setSettings(Settings.builder().put("index.refresh_interval", "10")).execute().actionGet();
|
||||||
fail("Expected IllegalArgumentException");
|
fail("Expected IllegalArgumentException");
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
assertThat(e.getMessage(), containsString("[index.refresh_interval] with value [10]"));
|
assertThat(e.getMessage(), containsString("[index.refresh_interval] with value [10]"));
|
||||||
|
@ -360,7 +365,8 @@ public class ClusterSettingsIT extends ESIntegTestCase {
|
||||||
final IllegalArgumentException e =
|
final IllegalArgumentException e =
|
||||||
expectThrows(
|
expectThrows(
|
||||||
IllegalArgumentException.class,
|
IllegalArgumentException.class,
|
||||||
() -> client().admin().cluster().prepareUpdateSettings().setTransientSettings(Settings.builder().put("logger._root", "BOOM")).execute().actionGet());
|
() -> client().admin().cluster().prepareUpdateSettings()
|
||||||
|
.setTransientSettings(Settings.builder().put("logger._root", "BOOM")).execute().actionGet());
|
||||||
assertEquals("Unknown level constant [BOOM].", e.getMessage());
|
assertEquals("Unknown level constant [BOOM].", e.getMessage());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -53,7 +53,8 @@ public class ClusterSearchShardsIT extends ESIntegTestCase {
|
||||||
|
|
||||||
public void testSingleShardAllocation() throws Exception {
|
public void testSingleShardAllocation() throws Exception {
|
||||||
client().admin().indices().prepareCreate("test").setSettings(Settings.builder()
|
client().admin().indices().prepareCreate("test").setSettings(Settings.builder()
|
||||||
.put("index.number_of_shards", "1").put("index.number_of_replicas", 0).put("index.routing.allocation.include.tag", "A")).execute().actionGet();
|
.put("index.number_of_shards", "1").put("index.number_of_replicas", 0)
|
||||||
|
.put("index.routing.allocation.include.tag", "A")).execute().actionGet();
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
ClusterSearchShardsResponse response = client().admin().cluster().prepareSearchShards("test").execute().actionGet();
|
ClusterSearchShardsResponse response = client().admin().cluster().prepareSearchShards("test").execute().actionGet();
|
||||||
assertThat(response.getGroups().length, equalTo(1));
|
assertThat(response.getGroups().length, equalTo(1));
|
||||||
|
@ -75,7 +76,8 @@ public class ClusterSearchShardsIT extends ESIntegTestCase {
|
||||||
|
|
||||||
public void testMultipleShardsSingleNodeAllocation() throws Exception {
|
public void testMultipleShardsSingleNodeAllocation() throws Exception {
|
||||||
client().admin().indices().prepareCreate("test").setSettings(Settings.builder()
|
client().admin().indices().prepareCreate("test").setSettings(Settings.builder()
|
||||||
.put("index.number_of_shards", "4").put("index.number_of_replicas", 0).put("index.routing.allocation.include.tag", "A")).execute().actionGet();
|
.put("index.number_of_shards", "4").put("index.number_of_replicas", 0)
|
||||||
|
.put("index.routing.allocation.include.tag", "A")).execute().actionGet();
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
||||||
ClusterSearchShardsResponse response = client().admin().cluster().prepareSearchShards("test").execute().actionGet();
|
ClusterSearchShardsResponse response = client().admin().cluster().prepareSearchShards("test").execute().actionGet();
|
||||||
|
|
|
@ -60,28 +60,32 @@ import static org.hamcrest.Matchers.sameInstance;
|
||||||
public class RoutingIteratorTests extends ESAllocationTestCase {
|
public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
public void testEmptyIterator() {
|
public void testEmptyIterator() {
|
||||||
ShardShuffler shuffler = new RotationShardShuffler(0);
|
ShardShuffler shuffler = new RotationShardShuffler(0);
|
||||||
ShardIterator shardIterator = new PlainShardIterator(new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
ShardIterator shardIterator = new PlainShardIterator(
|
||||||
|
new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
|
|
||||||
shardIterator = new PlainShardIterator(new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
shardIterator = new PlainShardIterator(
|
||||||
|
new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
|
|
||||||
shardIterator = new PlainShardIterator(new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
shardIterator = new PlainShardIterator(
|
||||||
|
new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
|
|
||||||
shardIterator = new PlainShardIterator(new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
shardIterator = new PlainShardIterator(
|
||||||
|
new ShardId("test1", "_na_", 0), shuffler.shuffle(Collections.<ShardRouting>emptyList()));
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
assertThat(shardIterator.nextOrNull(), nullValue());
|
assertThat(shardIterator.nextOrNull(), nullValue());
|
||||||
assertThat(shardIterator.remaining(), equalTo(0));
|
assertThat(shardIterator.remaining(), equalTo(0));
|
||||||
|
@ -243,7 +247,8 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
Map<String, String> node1Attributes = new HashMap<>();
|
Map<String, String> node1Attributes = new HashMap<>();
|
||||||
node1Attributes.put("rack_id", "rack_1");
|
node1Attributes.put("rack_id", "rack_1");
|
||||||
|
@ -263,7 +268,8 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
|
||||||
// after all are started, check routing iteration
|
// after all are started, check routing iteration
|
||||||
ShardIterator shardIterator = clusterState.routingTable().index("test").shard(0).preferAttributesActiveInitializingShardsIt(Arrays.asList("rack_id"), clusterState.nodes());
|
ShardIterator shardIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.preferAttributesActiveInitializingShardsIt(Arrays.asList("rack_id"), clusterState.nodes());
|
||||||
ShardRouting shardRouting = shardIterator.nextOrNull();
|
ShardRouting shardRouting = shardIterator.nextOrNull();
|
||||||
assertThat(shardRouting, notNullValue());
|
assertThat(shardRouting, notNullValue());
|
||||||
assertThat(shardRouting.currentNodeId(), equalTo("node1"));
|
assertThat(shardRouting.currentNodeId(), equalTo("node1"));
|
||||||
|
@ -271,7 +277,8 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
assertThat(shardRouting, notNullValue());
|
assertThat(shardRouting, notNullValue());
|
||||||
assertThat(shardRouting.currentNodeId(), equalTo("node2"));
|
assertThat(shardRouting.currentNodeId(), equalTo("node2"));
|
||||||
|
|
||||||
shardIterator = clusterState.routingTable().index("test").shard(0).preferAttributesActiveInitializingShardsIt(Arrays.asList("rack_id"), clusterState.nodes());
|
shardIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.preferAttributesActiveInitializingShardsIt(Arrays.asList("rack_id"), clusterState.nodes());
|
||||||
shardRouting = shardIterator.nextOrNull();
|
shardRouting = shardIterator.nextOrNull();
|
||||||
assertThat(shardRouting, notNullValue());
|
assertThat(shardRouting, notNullValue());
|
||||||
assertThat(shardRouting.currentNodeId(), equalTo("node1"));
|
assertThat(shardRouting.currentNodeId(), equalTo("node1"));
|
||||||
|
@ -294,7 +301,8 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
.add(newNode("fred", "node1", singletonMap("disk", "ebs")))
|
.add(newNode("fred", "node1", singletonMap("disk", "ebs")))
|
||||||
|
@ -306,19 +314,23 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
|
|
||||||
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
clusterState = strategy.applyStartedShards(clusterState, clusterState.getRoutingNodes().shardsWithState(INITIALIZING));
|
||||||
|
|
||||||
ShardsIterator shardsIterator = clusterState.routingTable().index("test").shard(0).onlyNodeSelectorActiveInitializingShardsIt("disk:ebs",clusterState.nodes());
|
ShardsIterator shardsIterator = clusterState.routingTable().index("test")
|
||||||
|
.shard(0).onlyNodeSelectorActiveInitializingShardsIt("disk:ebs",clusterState.nodes());
|
||||||
assertThat(shardsIterator.size(), equalTo(1));
|
assertThat(shardsIterator.size(), equalTo(1));
|
||||||
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
||||||
|
|
||||||
shardsIterator = clusterState.routingTable().index("test").shard(0).onlyNodeSelectorActiveInitializingShardsIt("dis*:eph*",clusterState.nodes());
|
shardsIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.onlyNodeSelectorActiveInitializingShardsIt("dis*:eph*",clusterState.nodes());
|
||||||
assertThat(shardsIterator.size(), equalTo(1));
|
assertThat(shardsIterator.size(), equalTo(1));
|
||||||
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node2"));
|
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node2"));
|
||||||
|
|
||||||
shardsIterator = clusterState.routingTable().index("test").shard(0).onlyNodeSelectorActiveInitializingShardsIt("fred",clusterState.nodes());
|
shardsIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.onlyNodeSelectorActiveInitializingShardsIt("fred",clusterState.nodes());
|
||||||
assertThat(shardsIterator.size(), equalTo(1));
|
assertThat(shardsIterator.size(), equalTo(1));
|
||||||
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
||||||
|
|
||||||
shardsIterator = clusterState.routingTable().index("test").shard(0).onlyNodeSelectorActiveInitializingShardsIt("bar*",clusterState.nodes());
|
shardsIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.onlyNodeSelectorActiveInitializingShardsIt("bar*",clusterState.nodes());
|
||||||
assertThat(shardsIterator.size(), equalTo(1));
|
assertThat(shardsIterator.size(), equalTo(1));
|
||||||
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node2"));
|
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node2"));
|
||||||
|
|
||||||
|
@ -341,13 +353,15 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
shardsIterator = clusterState.routingTable().index("test").shard(0).onlyNodeSelectorActiveInitializingShardsIt("welma", clusterState.nodes());
|
shardsIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.onlyNodeSelectorActiveInitializingShardsIt("welma", clusterState.nodes());
|
||||||
fail("should have raised illegalArgumentException");
|
fail("should have raised illegalArgumentException");
|
||||||
} catch (IllegalArgumentException illegal) {
|
} catch (IllegalArgumentException illegal) {
|
||||||
//expected exception
|
//expected exception
|
||||||
}
|
}
|
||||||
|
|
||||||
shardsIterator = clusterState.routingTable().index("test").shard(0).onlyNodeSelectorActiveInitializingShardsIt("fred",clusterState.nodes());
|
shardsIterator = clusterState.routingTable().index("test").shard(0)
|
||||||
|
.onlyNodeSelectorActiveInitializingShardsIt("fred",clusterState.nodes());
|
||||||
assertThat(shardsIterator.size(), equalTo(1));
|
assertThat(shardsIterator.size(), equalTo(1));
|
||||||
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
assertThat(shardsIterator.nextOrNull().currentNodeId(),equalTo("node1"));
|
||||||
}
|
}
|
||||||
|
@ -366,7 +380,8 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
.addAsNew(metaData.index("test"))
|
.addAsNew(metaData.index("test"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
ClusterState clusterState = ClusterState.builder(ClusterName.CLUSTER_NAME_SETTING
|
||||||
|
.getDefault(Settings.EMPTY)).metaData(metaData).routingTable(routingTable).build();
|
||||||
|
|
||||||
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
clusterState = ClusterState.builder(clusterState).nodes(DiscoveryNodes.builder()
|
||||||
.add(newNode("node1"))
|
.add(newNode("node1"))
|
||||||
|
@ -382,7 +397,8 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
OperationRouting operationRouting = new OperationRouting(Settings.EMPTY, new ClusterSettings(Settings.EMPTY,
|
OperationRouting operationRouting = new OperationRouting(Settings.EMPTY, new ClusterSettings(Settings.EMPTY,
|
||||||
ClusterSettings.BUILT_IN_CLUSTER_SETTINGS));
|
ClusterSettings.BUILT_IN_CLUSTER_SETTINGS));
|
||||||
|
|
||||||
GroupShardsIterator<ShardIterator> shardIterators = operationRouting.searchShards(clusterState, new String[]{"test"}, null, "_shards:0");
|
GroupShardsIterator<ShardIterator> shardIterators = operationRouting
|
||||||
|
.searchShards(clusterState, new String[]{"test"}, null, "_shards:0");
|
||||||
assertThat(shardIterators.size(), equalTo(1));
|
assertThat(shardIterators.size(), equalTo(1));
|
||||||
assertThat(shardIterators.iterator().next().shardId().id(), equalTo(0));
|
assertThat(shardIterators.iterator().next().shardId().id(), equalTo(0));
|
||||||
|
|
||||||
|
@ -401,12 +417,14 @@ public class RoutingIteratorTests extends ESAllocationTestCase {
|
||||||
assertThat(shardIterators.iterator().next().shardId().id(), equalTo(0));
|
assertThat(shardIterators.iterator().next().shardId().id(), equalTo(0));
|
||||||
assertThat(shardIterators.iterator().next().nextOrNull().currentNodeId(), not(equalTo(firstRoundNodeId)));
|
assertThat(shardIterators.iterator().next().nextOrNull().currentNodeId(), not(equalTo(firstRoundNodeId)));
|
||||||
|
|
||||||
shardIterators = operationRouting.searchShards(clusterState, new String[]{"test"}, null, "_shards:0|_prefer_nodes:node1");
|
shardIterators = operationRouting.searchShards(clusterState, new String[]{"test"},
|
||||||
|
null, "_shards:0|_prefer_nodes:node1");
|
||||||
assertThat(shardIterators.size(), equalTo(1));
|
assertThat(shardIterators.size(), equalTo(1));
|
||||||
assertThat(shardIterators.iterator().next().shardId().id(), equalTo(0));
|
assertThat(shardIterators.iterator().next().shardId().id(), equalTo(0));
|
||||||
assertThat(shardIterators.iterator().next().nextOrNull().currentNodeId(), equalTo("node1"));
|
assertThat(shardIterators.iterator().next().nextOrNull().currentNodeId(), equalTo("node1"));
|
||||||
|
|
||||||
shardIterators = operationRouting.searchShards(clusterState, new String[]{"test"}, null, "_shards:0|_prefer_nodes:node1,node2");
|
shardIterators = operationRouting.searchShards(clusterState, new String[]{"test"},
|
||||||
|
null, "_shards:0|_prefer_nodes:node1,node2");
|
||||||
assertThat(shardIterators.size(), equalTo(1));
|
assertThat(shardIterators.size(), equalTo(1));
|
||||||
Iterator<ShardIterator> iterator = shardIterators.iterator();
|
Iterator<ShardIterator> iterator = shardIterators.iterator();
|
||||||
final ShardIterator it = iterator.next();
|
final ShardIterator it = iterator.next();
|
||||||
|
|
Loading…
Reference in New Issue