Skip to content

Commit

Permalink
Autoscaling test scale from empty with node attrs (#68730)
Browse files Browse the repository at this point in the history
Autoscaling expects data tiers to be used exclusively both for node
roles and in ILM policies. This commit adds a test demonstrating that
as well as documentation for the behavior.
  • Loading branch information
henningandersen authored Feb 22, 2021
1 parent f2a1e02 commit d4a7aa2
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,11 @@ the current data set. It signals that additional storage capacity is necessary
when existing capacity has been exceeded (reactively).

The reactive storage decider is enabled for all policies governing data nodes and has no configuration options.

The decider relies partially on using <<data-tier-allocation,data tier preference>>
allocation rather than node attributes. In particular, scaling a data tier into
existence (starting the first node in a tier) will result in starting a node in
any data tier that is empty if not using allocation based on data tier preference.
Using the <<ilm-migrate,ILM migrate>> action to migrate between tiers is the
preferred way of allocating to tiers and fully supports scaling a tier into
existence.
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import org.elasticsearch.cluster.node.DiscoveryNodeRole;
import org.elasticsearch.common.settings.ClusterSettings;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.node.Node;
import org.elasticsearch.test.ESIntegTestCase;
import org.elasticsearch.test.NodeRoles;
import org.elasticsearch.xpack.autoscaling.action.GetAutoscalingCapacityAction;
Expand Down Expand Up @@ -146,6 +147,49 @@ private void testScaleFromEmptyWarm(boolean allocatable) throws Exception {

}

public void testScaleFromEmptyLegacy() {
internalCluster().startMasterOnlyNode();
internalCluster().startNode(
NodeRoles.onlyRole(
Settings.builder().put(Node.NODE_ATTRIBUTES.getKey() + "data_tier", "hot").build(),
DataTier.DATA_HOT_NODE_ROLE
)
);
putAutoscalingPolicy("hot", DataTier.DATA_HOT);
putAutoscalingPolicy("warm", DataTier.DATA_WARM);
putAutoscalingPolicy("cold", DataTier.DATA_COLD);

final String indexName = randomAlphaOfLength(10).toLowerCase(Locale.ROOT);
assertAcked(
prepareCreate(indexName).setSettings(
Settings.builder()
.put(IndexMetadata.SETTING_NUMBER_OF_REPLICAS, 0)
.put(IndexMetadata.SETTING_NUMBER_OF_SHARDS, 6)
.put(INDEX_STORE_STATS_REFRESH_INTERVAL_SETTING.getKey(), "0ms")
.put(IndexMetadata.INDEX_ROUTING_INCLUDE_GROUP_SETTING.getKey() + "data_tier", "hot")
.build()
)
);
refresh();
assertThat(capacity().results().get("warm").requiredCapacity().total().storage().getBytes(), Matchers.equalTo(0L));
assertThat(capacity().results().get("cold").requiredCapacity().total().storage().getBytes(), Matchers.equalTo(0L));

assertAcked(
client().admin()
.indices()
.updateSettings(
new UpdateSettingsRequest(indexName).settings(
Settings.builder().put(IndexMetadata.INDEX_ROUTING_INCLUDE_GROUP_SETTING.getKey() + "data_tier", "warm")
)
)
.actionGet()
);

assertThat(capacity().results().get("warm").requiredCapacity().total().storage().getBytes(), Matchers.greaterThan(0L));
// this is not desirable, but one of the caveats of not using data tiers in the ILM policy.
assertThat(capacity().results().get("cold").requiredCapacity().total().storage().getBytes(), Matchers.greaterThan(0L));
}

/**
* Verify that the list of roles includes all data roles to ensure we consider adding future data roles.
*/
Expand Down

0 comments on commit d4a7aa2

Please sign in to comment.