Fix watermark errors

Fix watermark errors

When a data node is critically low on disk space and has reached the flood-stage disk usage watermark, the following error is logged: Error: disk usage exceeded flood-stage watermark, index has read-only-allow-delete block.

To prevent a full disk, when a node reaches this watermark, Elasticsearch blocks writes to any index with a shard on the node. If the block affects related system indices, Kibana and other Elastic Stack features may become unavailable. For example, this could induce Kibana’s Kibana Server is not Ready yet error message.

Elasticsearch will automatically remove the write block when the affected node’s disk usage falls below the high disk watermark. To achieve this, Elasticsearch attempts to rebalance some of the affected node’s shards to other nodes in the same data tier.

Monitor rebalancing

To verify that shards are moving off the affected node until it falls below high watermark., use the cat shards API and cat recovery API:

  1. resp = client.cat.shards(
  2. v=True,
  3. )
  4. print(resp)
  5. resp1 = client.cat.recovery(
  6. v=True,
  7. active_only=True,
  8. )
  9. print(resp1)
  1. const response = await client.cat.shards({
  2. v: "true",
  3. });
  4. console.log(response);
  5. const response1 = await client.cat.recovery({
  6. v: "true",
  7. active_only: "true",
  8. });
  9. console.log(response1);
  1. GET _cat/shards?v=true
  2. GET _cat/recovery?v=true&active_only=true

If shards remain on the node keeping it about high watermark, use the cluster allocation explanation API to get an explanation for their allocation status.

  1. resp = client.cluster.allocation_explain(
  2. index="my-index",
  3. shard=0,
  4. primary=False,
  5. )
  6. print(resp)
  1. const response = await client.cluster.allocationExplain({
  2. index: "my-index",
  3. shard: 0,
  4. primary: false,
  5. });
  6. console.log(response);
  1. GET _cluster/allocation/explain
  2. {
  3. "index": "my-index",
  4. "shard": 0,
  5. "primary": false
  6. }

Temporary Relief

To immediately restore write operations, you can temporarily increase the disk watermarks and remove the write block.

  1. resp = client.cluster.put_settings(
  2. persistent={
  3. "cluster.routing.allocation.disk.watermark.low": "90%",
  4. "cluster.routing.allocation.disk.watermark.low.max_headroom": "100GB",
  5. "cluster.routing.allocation.disk.watermark.high": "95%",
  6. "cluster.routing.allocation.disk.watermark.high.max_headroom": "20GB",
  7. "cluster.routing.allocation.disk.watermark.flood_stage": "97%",
  8. "cluster.routing.allocation.disk.watermark.flood_stage.max_headroom": "5GB",
  9. "cluster.routing.allocation.disk.watermark.flood_stage.frozen": "97%",
  10. "cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom": "5GB"
  11. },
  12. )
  13. print(resp)
  14. resp1 = client.indices.put_settings(
  15. index="*",
  16. expand_wildcards="all",
  17. settings={
  18. "index.blocks.read_only_allow_delete": None
  19. },
  20. )
  21. print(resp1)
  1. response = client.cluster.put_settings(
  2. body: {
  3. persistent: {
  4. 'cluster.routing.allocation.disk.watermark.low' => '90%',
  5. 'cluster.routing.allocation.disk.watermark.low.max_headroom' => '100GB',
  6. 'cluster.routing.allocation.disk.watermark.high' => '95%',
  7. 'cluster.routing.allocation.disk.watermark.high.max_headroom' => '20GB',
  8. 'cluster.routing.allocation.disk.watermark.flood_stage' => '97%',
  9. 'cluster.routing.allocation.disk.watermark.flood_stage.max_headroom' => '5GB',
  10. 'cluster.routing.allocation.disk.watermark.flood_stage.frozen' => '97%',
  11. 'cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom' => '5GB'
  12. }
  13. }
  14. )
  15. puts response
  16. response = client.indices.put_settings(
  17. index: '*',
  18. expand_wildcards: 'all',
  19. body: {
  20. 'index.blocks.read_only_allow_delete' => nil
  21. }
  22. )
  23. puts response
  1. const response = await client.cluster.putSettings({
  2. persistent: {
  3. "cluster.routing.allocation.disk.watermark.low": "90%",
  4. "cluster.routing.allocation.disk.watermark.low.max_headroom": "100GB",
  5. "cluster.routing.allocation.disk.watermark.high": "95%",
  6. "cluster.routing.allocation.disk.watermark.high.max_headroom": "20GB",
  7. "cluster.routing.allocation.disk.watermark.flood_stage": "97%",
  8. "cluster.routing.allocation.disk.watermark.flood_stage.max_headroom": "5GB",
  9. "cluster.routing.allocation.disk.watermark.flood_stage.frozen": "97%",
  10. "cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom":
  11. "5GB",
  12. },
  13. });
  14. console.log(response);
  15. const response1 = await client.indices.putSettings({
  16. index: "*",
  17. expand_wildcards: "all",
  18. settings: {
  19. "index.blocks.read_only_allow_delete": null,
  20. },
  21. });
  22. console.log(response1);
  1. PUT _cluster/settings
  2. {
  3. "persistent": {
  4. "cluster.routing.allocation.disk.watermark.low": "90%",
  5. "cluster.routing.allocation.disk.watermark.low.max_headroom": "100GB",
  6. "cluster.routing.allocation.disk.watermark.high": "95%",
  7. "cluster.routing.allocation.disk.watermark.high.max_headroom": "20GB",
  8. "cluster.routing.allocation.disk.watermark.flood_stage": "97%",
  9. "cluster.routing.allocation.disk.watermark.flood_stage.max_headroom": "5GB",
  10. "cluster.routing.allocation.disk.watermark.flood_stage.frozen": "97%",
  11. "cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom": "5GB"
  12. }
  13. }
  14. PUT */_settings?expand_wildcards=all
  15. {
  16. "index.blocks.read_only_allow_delete": null
  17. }

When a long-term solution is in place, to reset or reconfigure the disk watermarks:

  1. resp = client.cluster.put_settings(
  2. persistent={
  3. "cluster.routing.allocation.disk.watermark.low": None,
  4. "cluster.routing.allocation.disk.watermark.low.max_headroom": None,
  5. "cluster.routing.allocation.disk.watermark.high": None,
  6. "cluster.routing.allocation.disk.watermark.high.max_headroom": None,
  7. "cluster.routing.allocation.disk.watermark.flood_stage": None,
  8. "cluster.routing.allocation.disk.watermark.flood_stage.max_headroom": None,
  9. "cluster.routing.allocation.disk.watermark.flood_stage.frozen": None,
  10. "cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom": None
  11. },
  12. )
  13. print(resp)
  1. response = client.cluster.put_settings(
  2. body: {
  3. persistent: {
  4. 'cluster.routing.allocation.disk.watermark.low' => nil,
  5. 'cluster.routing.allocation.disk.watermark.low.max_headroom' => nil,
  6. 'cluster.routing.allocation.disk.watermark.high' => nil,
  7. 'cluster.routing.allocation.disk.watermark.high.max_headroom' => nil,
  8. 'cluster.routing.allocation.disk.watermark.flood_stage' => nil,
  9. 'cluster.routing.allocation.disk.watermark.flood_stage.max_headroom' => nil,
  10. 'cluster.routing.allocation.disk.watermark.flood_stage.frozen' => nil,
  11. 'cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom' => nil
  12. }
  13. }
  14. )
  15. puts response
  1. const response = await client.cluster.putSettings({
  2. persistent: {
  3. "cluster.routing.allocation.disk.watermark.low": null,
  4. "cluster.routing.allocation.disk.watermark.low.max_headroom": null,
  5. "cluster.routing.allocation.disk.watermark.high": null,
  6. "cluster.routing.allocation.disk.watermark.high.max_headroom": null,
  7. "cluster.routing.allocation.disk.watermark.flood_stage": null,
  8. "cluster.routing.allocation.disk.watermark.flood_stage.max_headroom": null,
  9. "cluster.routing.allocation.disk.watermark.flood_stage.frozen": null,
  10. "cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom":
  11. null,
  12. },
  13. });
  14. console.log(response);
  1. PUT _cluster/settings
  2. {
  3. "persistent": {
  4. "cluster.routing.allocation.disk.watermark.low": null,
  5. "cluster.routing.allocation.disk.watermark.low.max_headroom": null,
  6. "cluster.routing.allocation.disk.watermark.high": null,
  7. "cluster.routing.allocation.disk.watermark.high.max_headroom": null,
  8. "cluster.routing.allocation.disk.watermark.flood_stage": null,
  9. "cluster.routing.allocation.disk.watermark.flood_stage.max_headroom": null,
  10. "cluster.routing.allocation.disk.watermark.flood_stage.frozen": null,
  11. "cluster.routing.allocation.disk.watermark.flood_stage.frozen.max_headroom": null
  12. }
  13. }

Resolve

As a long-term solution, we recommend you do one of the following best suited to your use case:

  • add nodes to the affected data tiers

    You should enable autoscaling for clusters deployed using our Elasticsearch Service, Elastic Cloud Enterprise, and Elastic Cloud on Kubernetes platforms.

  • upgrade existing nodes to increase disk space

    On Elasticsearch Service, Elastic Support intervention may become necessary if cluster health reaches status:red.

  • delete unneeded indices using the delete index API

  • update related ILM policy to push indices through to later data tiers