Fix other role nodes out of disk

Fix other role nodes out of disk

Elasticsearch can use dedicated nodes to execute other functions apart from storing data or coordinating the cluster, for example machine learning. If one or more of these nodes are running out of space, you need to ensure that they have enough disk space to function. If the health API reports that a node that is not a master and does not contain data is out of space you need to increase the disk capacity of this node.

Elasticsearch Service Self-managed

  1. Log in to the Elastic Cloud console.
  2. On the Elasticsearch Service panel, click the gear under the Manage deployment column that corresponds to the name of your deployment.
  3. Go to Actions > Edit deployment and then go to the Coordinating instances or the Machine Learning instances section depending on the roles listed in the diagnosis:

    Increase disk capacity of other nodes

  4. Choose a larger than the pre-selected capacity configuration from the drop-down menu and click save. Wait for the plan to be applied and the problem should be resolved.

In order to increase the disk capacity of any other node, you will need to replace the instance that has run out of space with one of higher disk capacity.

  1. First, retrieve the disk threshold that will indicate how much disk space is needed. The relevant threshold is the high watermark and can be retrieved via the following command:

    1. resp = client.cluster.get_settings(
    2. include_defaults=True,
    3. filter_path="*.cluster.routing.allocation.disk.watermark.high*",
    4. )
    5. print(resp)
    1. response = client.cluster.get_settings(
    2. include_defaults: true,
    3. filter_path: '*.cluster.routing.allocation.disk.watermark.high*'
    4. )
    5. puts response
    1. const response = await client.cluster.getSettings({
    2. include_defaults: "true",
    3. filter_path: "*.cluster.routing.allocation.disk.watermark.high*",
    4. });
    5. console.log(response);
    1. GET _cluster/settings?include_defaults&filter_path=*.cluster.routing.allocation.disk.watermark.high*

    The response will look like this:

    1. {
    2. "defaults": {
    3. "cluster": {
    4. "routing": {
    5. "allocation": {
    6. "disk": {
    7. "watermark": {
    8. "high": "90%",
    9. "high.max_headroom": "150GB"
    10. }
    11. }
    12. }
    13. }
    14. }
    15. }

    The above means that in order to resolve the disk shortage we need to either drop our disk usage below the 90% or have more than 150GB available, read more how this threshold works here.

  2. The next step is to find out the current disk usage, this will allow to calculate how much extra space is needed. In the following example, we show only a machine learning node for readability purposes:

    1. resp = client.cat.nodes(
    2. v=True,
    3. h="name,node.role,disk.used_percent,disk.used,disk.avail,disk.total",
    4. )
    5. print(resp)
    1. response = client.cat.nodes(
    2. v: true,
    3. h: 'name,node.role,disk.used_percent,disk.used,disk.avail,disk.total'
    4. )
    5. puts response
    1. const response = await client.cat.nodes({
    2. v: "true",
    3. h: "name,node.role,disk.used_percent,disk.used,disk.avail,disk.total",
    4. });
    5. console.log(response);
    1. GET /_cat/nodes?v&h=name,node.role,disk.used_percent,disk.used,disk.avail,disk.total

    The response will look like this:

    1. name node.role disk.used_percent disk.used disk.avail disk.total
    2. instance-0000000000 l 85.31 3.4gb 500mb 4gb
  3. The desired situation is to drop the disk usage below the relevant threshold, in our example 90%. Consider adding some padding, so it will not go over the threshold soon. Assuming you have the new node ready, add this node to the cluster.

  4. Verify that the new node has joined the cluster:

    1. resp = client.cat.nodes(
    2. v=True,
    3. h="name,node.role,disk.used_percent,disk.used,disk.avail,disk.total",
    4. )
    5. print(resp)
    1. response = client.cat.nodes(
    2. v: true,
    3. h: 'name,node.role,disk.used_percent,disk.used,disk.avail,disk.total'
    4. )
    5. puts response
    1. const response = await client.cat.nodes({
    2. v: "true",
    3. h: "name,node.role,disk.used_percent,disk.used,disk.avail,disk.total",
    4. });
    5. console.log(response);
    1. GET /_cat/nodes?v&h=name,node.role,disk.used_percent,disk.used,disk.avail,disk.total

    The response will look like this:

    1. name node.role disk.used_percent disk.used disk.avail disk.total
    2. instance-0000000000 l 85.31 3.4gb 500mb 4gb
    3. instance-0000000001 l 41.31 3.4gb 4.5gb 8gb
  5. Now you can remove the out of disk space instance.