Allow Elasticsearch to allocate the index

Allow Elasticsearch to allocate the index

The allocation of data can be controlled using the enable allocation configuration. In certain circumstances users might want to temporarily disable or restrict the allocation of data.

Forgetting to re-allow all data allocation can lead to unassigned shards.

In order to (re)allow all data to be allocated follow these steps:

Elasticsearch Service Self-managed

In order to get the shards assigned we’ll need to change the value of the configuration that restricts the assignemnt of the shards to all.

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. Inspect the index.routing.allocation.enable index setting for the index with unassigned shards:

    1. resp = client.indices.get_settings(
    2. index="my-index-000001",
    3. name="index.routing.allocation.enable",
    4. flat_settings=True,
    5. )
    6. print(resp)
    1. response = client.indices.get_settings(
    2. index: 'my-index-000001',
    3. name: 'index.routing.allocation.enable',
    4. flat_settings: true
    5. )
    6. puts response
    1. const response = await client.indices.getSettings({
    2. index: "my-index-000001",
    3. name: "index.routing.allocation.enable",
    4. flat_settings: "true",
    5. });
    6. console.log(response);
    1. GET /my-index-000001/_settings/index.routing.allocation.enable?flat_settings

    The response will look like this:

    1. {
    2. "my-index-000001": {
    3. "settings": {
    4. "index.routing.allocation.enable": "none"
    5. }
    6. }
    7. }

    Represents the current configured value that controls if the index is allowed to be partially or totally allocated.

  5. Change the configuration value to allow the index to be fully allocated:

    1. resp = client.indices.put_settings(
    2. index="my-index-000001",
    3. settings={
    4. "index": {
    5. "routing.allocation.enable": "all"
    6. }
    7. },
    8. )
    9. print(resp)
    1. response = client.indices.put_settings(
    2. index: 'my-index-000001',
    3. body: {
    4. index: {
    5. 'routing.allocation.enable' => 'all'
    6. }
    7. }
    8. )
    9. puts response
    1. const response = await client.indices.putSettings({
    2. index: "my-index-000001",
    3. settings: {
    4. index: {
    5. "routing.allocation.enable": "all",
    6. },
    7. },
    8. });
    9. console.log(response);
    1. PUT /my-index-000001/_settings
    2. {
    3. "index" : {
    4. "routing.allocation.enable" : "all"
    5. }
    6. }

    The new value for the allocation.enable configuration for the my-index-000001 index is changed to allow all the shards to be allocated.

In order to get the shards assigned we’ll need to change the value of the configuration that restricts the assignemnt of the shards to all.

  1. Inspect the index.routing.allocation.enable index setting for the index with unassigned shards:

    1. resp = client.indices.get_settings(
    2. index="my-index-000001",
    3. name="index.routing.allocation.enable",
    4. flat_settings=True,
    5. )
    6. print(resp)
    1. response = client.indices.get_settings(
    2. index: 'my-index-000001',
    3. name: 'index.routing.allocation.enable',
    4. flat_settings: true
    5. )
    6. puts response
    1. const response = await client.indices.getSettings({
    2. index: "my-index-000001",
    3. name: "index.routing.allocation.enable",
    4. flat_settings: "true",
    5. });
    6. console.log(response);
    1. GET /my-index-000001/_settings/index.routing.allocation.enable?flat_settings

    The response will look like this:

    1. {
    2. "my-index-000001": {
    3. "settings": {
    4. "index.routing.allocation.enable": "none"
    5. }
    6. }
    7. }

    Represents the current configured value that controls if the index is allowed to be partially or totally allocated.

  2. Change the configuration value to allow the index to be fully allocated:

    1. resp = client.indices.put_settings(
    2. index="my-index-000001",
    3. settings={
    4. "index": {
    5. "routing.allocation.enable": "all"
    6. }
    7. },
    8. )
    9. print(resp)
    1. response = client.indices.put_settings(
    2. index: 'my-index-000001',
    3. body: {
    4. index: {
    5. 'routing.allocation.enable' => 'all'
    6. }
    7. }
    8. )
    9. puts response
    1. const response = await client.indices.putSettings({
    2. index: "my-index-000001",
    3. settings: {
    4. index: {
    5. "routing.allocation.enable": "all",
    6. },
    7. },
    8. });
    9. console.log(response);
    1. PUT /my-index-000001/_settings
    2. {
    3. "index" : {
    4. "routing.allocation.enable" : "all"
    5. }
    6. }

    The new value for the allocation.enable configuration for the my-index-000001 index is changed to allow all the shards to be allocated.