disk_allocator.asciidoc 5.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. [[disk-based-shard-allocation]]
  2. ==== Disk-based shard allocation settings
  3. [[disk-based-shard-allocation-description]]
  4. // tag::disk-based-shard-allocation-description-tag[]
  5. {es} considers the available disk space on a node before deciding
  6. whether to allocate new shards to that node or to actively relocate shards away
  7. from that node.
  8. You can use the following settings to control disk-based allocation:
  9. `cluster.routing.allocation.disk.threshold_enabled`::
  10. (<<dynamic-cluster-setting,Dynamic>>)
  11. Defaults to `true`. Set to `false` to disable the disk allocation decider.
  12. [[cluster-routing-disk-threshold]]
  13. // tag::cluster-routing-disk-threshold-tag[]
  14. `cluster.routing.allocation.disk.threshold_enabled` {ess-icon}::
  15. (<<dynamic-cluster-setting,Dynamic>>)
  16. Defaults to `true`. Set to `false` to disable the disk allocation decider.
  17. // end::cluster-routing-disk-threshold-tag[]
  18. [[cluster-routing-watermark-low]]
  19. // tag::cluster-routing-watermark-low-tag[]
  20. `cluster.routing.allocation.disk.watermark.low` {ess-icon}::
  21. (<<dynamic-cluster-setting,Dynamic>>)
  22. Controls the low watermark for disk usage. It defaults to `85%`, meaning that {es} will not allocate shards to nodes that have more than 85% disk used. It can also be set to an absolute byte value (like `500mb`) to prevent {es} from allocating shards if less than the specified amount of space is available. This setting has no effect on the primary shards of newly-created indices but will prevent their replicas from being allocated.
  23. // end::cluster-routing-watermark-low-tag[]
  24. [[cluster-routing-watermark-high]]
  25. // tag::cluster-routing-watermark-high-tag[]
  26. `cluster.routing.allocation.disk.watermark.high` {ess-icon}::
  27. (<<dynamic-cluster-setting,Dynamic>>)
  28. Controls the high watermark. It defaults to `90%`, meaning that {es} will attempt to relocate shards away from a node whose disk usage is above 90%. It can also be set to an absolute byte value (similarly to the low watermark) to relocate shards away from a node if it has less than the specified amount of free space. This setting affects the allocation of all shards, whether previously allocated or not.
  29. // end::cluster-routing-watermark-high-tag[]
  30. `cluster.routing.allocation.disk.watermark.enable_for_single_data_node`::
  31. (<<static-cluster-setting,Static>>)
  32. For a single data node, the default is to disregard disk watermarks when
  33. making an allocation decision. This is deprecated behavior and will be
  34. changed in 8.0. This setting can be set to `true` to enable the
  35. disk watermarks for a single data node cluster (will become default in 8.0).
  36. [[cluster-routing-flood-stage]]
  37. // tag::cluster-routing-flood-stage-tag[]
  38. `cluster.routing.allocation.disk.watermark.flood_stage` {ess-icon}::
  39. +
  40. --
  41. (<<dynamic-cluster-setting,Dynamic>>)
  42. Controls the flood stage watermark, which defaults to 95%. {es} enforces a read-only index block (`index.blocks.read_only_allow_delete`) on every index that has one or more shards allocated on the node, and that has at least one disk exceeding the flood stage. This setting is a last resort to prevent nodes from running out of disk space. The index block is automatically released when the disk utilization falls below the high watermark.
  43. NOTE: You cannot mix the usage of percentage values and byte values within
  44. these settings. Either all values are set to percentage values, or all are set to byte values. This enforcement is so that {es} can validate that the settings are internally consistent, ensuring that the low disk threshold is less than the high disk threshold, and the high disk threshold is less than the flood stage threshold.
  45. An example of resetting the read-only index block on the `my-index-000001` index:
  46. [source,console]
  47. --------------------------------------------------
  48. PUT /my-index-000001/_settings
  49. {
  50. "index.blocks.read_only_allow_delete": null
  51. }
  52. --------------------------------------------------
  53. // TEST[setup:my_index]
  54. --
  55. // end::cluster-routing-flood-stage-tag[]
  56. `cluster.info.update.interval`::
  57. (<<dynamic-cluster-setting,Dynamic>>)
  58. How often {es} should check on disk usage for each node in the
  59. cluster. Defaults to `30s`.
  60. NOTE: Percentage values refer to used disk space, while byte values refer to
  61. free disk space. This can be confusing, since it flips the meaning of high and
  62. low. For example, it makes sense to set the low watermark to 10gb and the high
  63. watermark to 5gb, but not the other way around.
  64. An example of updating the low watermark to at least 100 gigabytes free, a high
  65. watermark of at least 50 gigabytes free, and a flood stage watermark of 10
  66. gigabytes free, and updating the information about the cluster every minute:
  67. [source,console]
  68. --------------------------------------------------
  69. PUT _cluster/settings
  70. {
  71. "transient": {
  72. "cluster.routing.allocation.disk.watermark.low": "100gb",
  73. "cluster.routing.allocation.disk.watermark.high": "50gb",
  74. "cluster.routing.allocation.disk.watermark.flood_stage": "10gb",
  75. "cluster.info.update.interval": "1m"
  76. }
  77. }
  78. --------------------------------------------------