Indices mix index allocation filters with data tiers node roles to move through data tiers

Indices mix index allocation filters with data tiers node roles to move through data tiers

Elasticsearch standardized the implementation of hot-warm-cold architectures to data tiers in version 7.10. Some indices and deployments might have not fully transitioned to data tiers and mix the new way of implementing the hot-warm-cold architecture with legacy based node attributes.

This could lead to unassigned shards or shards not transitioning to the desired tier.

In order to fix this follow the next steps:

Elasticsearch Service Self-managed

In order to get the shards assigned we need to call the migrate to data tiers routing API which will resolve the conflicting routing configurations towards using the standardized data tiers. This will also future-proof the system by migrating the index templates and ILM policies if needed.

Use Kibana

  1. Log in to the Elastic Cloud console.
  2. On the Elasticsearch Service panel, click the name of your deployment.

    If the name of your deployment is disabled your Kibana instances might be unhealthy, in which case please contact Elastic Support. If your deployment doesn’t include Kibana, all you need to do is enable it first.

  3. Open your deployment’s side navigation menu (placed under the Elastic logo in the upper left corner) and go to Dev Tools > Console.

    Kibana Console

  4. First, let’s stop index lifecycle management

    1. resp = client.ilm.stop()
    2. print(resp)
    1. response = client.ilm.stop
    2. puts response
    1. const response = await client.ilm.stop();
    2. console.log(response);
    1. POST /_ilm/stop

    The response will look like this:

    1. {
    2. "acknowledged": true
    3. }
  5. Wait for index lifecycle management to stop. Check the status until it returns STOPPED as follows:

    1. resp = client.ilm.get_status()
    2. print(resp)
    1. response = client.ilm.get_status
    2. puts response
    1. const response = await client.ilm.getStatus();
    2. console.log(response);
    1. GET /_ilm/status

    When index lifecycle management has successfully stopped the response will look like this:

    1. {
    2. "operation_mode": "STOPPED"
    3. }
  6. Migrate to data tiers

    1. resp = client.ilm.migrate_to_data_tiers()
    2. print(resp)
    1. response = client.ilm.migrate_to_data_tiers
    2. puts response
    1. const response = await client.ilm.migrateToDataTiers();
    2. console.log(response);
    1. POST /_ilm/migrate_to_data_tiers

    The response will look like this:

    1. {
    2. "dry_run": false,
    3. "migrated_ilm_policies":["policy_with_allocate_action"],
    4. "migrated_indices":["warm-index-to-migrate-000001"],
    5. "migrated_legacy_templates":["a-legacy-template"],
    6. "migrated_composable_templates":["a-composable-template"],
    7. "migrated_component_templates":["a-component-template"]
    8. }

    The ILM policies that were updated.

    The indices that were migrated to tier preference routing.

    The legacy index templates that were updated to not contain custom routing settings for the provided data attribute.

    The composable index templates that were updated to not contain custom routing settings for the provided data attribute.

    The component templates that were updated to not contain custom routing settings for the provided data attribute.

  7. Restart index lifecycle management

    1. resp = client.ilm.start()
    2. print(resp)
    1. response = client.ilm.start
    2. puts response
    1. const response = await client.ilm.start();
    2. console.log(response);
    1. POST /_ilm/start

    The response will look like this:

    1. {
    2. "acknowledged": true
    3. }

In order to get the shards assigned we need to make sure the deployment is using the data tiers node roles and then call the migrate to data tiers routing API which will resolve the conflicting routing configurations towards using the standardized data tiers. This will also future-proof the system by migrating the index templates and ILM policies if needed.

  1. In case your deployment is not yet using data tiers assign data nodes to the appropriate data tier. Configure the appropriate roles for each data node to assign it to one or more data tiers: data_hot, data_content, data_warm, data_cold, or data_frozen. For example, the following setting configures a node to be a data-only node in the hot and content tiers.

    1. node.roles [ data_hot, data_content ]
  2. Stop index lifecycle management

    1. resp = client.ilm.stop()
    2. print(resp)
    1. response = client.ilm.stop
    2. puts response
    1. const response = await client.ilm.stop();
    2. console.log(response);
    1. POST /_ilm/stop

    The response will look like this:

    1. {
    2. "acknowledged": true
    3. }
  3. Wait for index lifecycle management to stop. Check the status until it returns STOPPED as follows:

    1. resp = client.ilm.get_status()
    2. print(resp)
    1. response = client.ilm.get_status
    2. puts response
    1. const response = await client.ilm.getStatus();
    2. console.log(response);
    1. GET /_ilm/status

    When index lifecycle management has successfully stopped the response will look like this:

    1. {
    2. "operation_mode": "STOPPED"
    3. }
  4. Migrate to data tiers

    1. resp = client.ilm.migrate_to_data_tiers()
    2. print(resp)
    1. response = client.ilm.migrate_to_data_tiers
    2. puts response
    1. const response = await client.ilm.migrateToDataTiers();
    2. console.log(response);
    1. POST /_ilm/migrate_to_data_tiers

    The response will look like this:

    1. {
    2. "dry_run": false,
    3. "migrated_ilm_policies":["policy_with_allocate_action"],
    4. "migrated_indices":["warm-index-to-migrate-000001"],
    5. "migrated_legacy_templates":["a-legacy-template"],
    6. "migrated_composable_templates":["a-composable-template"],
    7. "migrated_component_templates":["a-component-template"]
    8. }

    The ILM policies that were updated.

    The indices that were migrated to tier preference routing.

    The legacy index templates that were updated to not contain custom routing settings for the provided data attribute.

    The composable index templates that were updated to not contain custom routing settings for the provided data attribute.

    The component templates that were updated to not contain custom routing settings for the provided data attribute.

  5. Restart index lifecycle management

    1. resp = client.ilm.start()
    2. print(resp)
    1. response = client.ilm.start
    2. puts response
    1. const response = await client.ilm.start();
    2. console.log(response);
    1. POST /_ilm/start

    The response will look like this:

    1. {
    2. "acknowledged": true
    3. }