| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 | [[index-modules-blocks]]== Index blocksIndex blocks limit the kind of operations that are available on a certainindex. The blocks come in different flavours, allowing to block write,read, or metadata operations. The blocks can be set / removed using dynamicindex settings, or can be added using a dedicated API, which also ensuresfor write blocks that, once successfully returning to the user, all shardsof the index are properly accounting for the block, for example that allin-flight writes to an index have been completed after adding the writeblock.[discrete][[index-block-settings]]=== Index block settingsThe following _dynamic_ index settings determine the blocks present on anindex:[[index-blocks-read-only]]`index.blocks.read_only`::    Set to `true` to make the index and index metadata read only, `false` to    allow writes and metadata changes.`index.blocks.read_only_allow_delete`::    Similar to `index.blocks.read_only`, but also allows deleting the index to    make more resources available. The <<disk-based-shard-allocation,disk-based shard    allocator>> may add and remove this block automatically.+Deleting documents from an index to release resources - rather than deleting the index itself - can increase the index size over time. When `index.blocks.read_only_allow_delete` is set to `true`, deleting documents is not permitted. However, deleting the index itself releases the read-only index block and makes resources available almost immediately.+IMPORTANT: {es} adds and removes the read-only index block automatically when the disk utilization falls below the high watermark, controlled by <<cluster-routing-flood-stage,cluster.routing.allocation.disk.watermark.flood_stage>>.`index.blocks.read`::    Set to `true` to disable read operations against the index.`index.blocks.write`::    Set to `true` to disable data write operations against the index. Unlike `read_only`,    this setting does not affect metadata. For instance, you can close an index with a `write`    block, but you cannot close an index with a `read_only` block.`index.blocks.metadata`::    Set to `true` to disable index metadata reads and writes.[discrete][[add-index-block]]=== Add index block APIAdds an index block to an index.[source,console]--------------------------------------------------PUT /my-index-000001/_block/write--------------------------------------------------// TEST[setup:my_index][discrete][[add-index-block-api-request]]==== {api-request-title}`PUT /<index>/_block/<block>`[discrete][role="child_attributes"][[add-index-block-api-path-params]]==== {api-path-parms-title}include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=index]+By default, you must explicitly name the indices you are adding blocks to.To allow the adding of blocks to indices with `_all`, `*`, or other wildcardexpressions, change the `action.destructive_requires_name` setting to `false`.You can update this setting in the `elasticsearch.yml` fileor using the <<cluster-update-settings,cluster update settings>> API.`<block>`::(Required, string)Block type to add to the index.+.Valid values for `<block>`[%collapsible%open]====`metadata`::Disable metadata changes, such as closing the index.`read`::Disable read operations.`read_only`::Disable write operations and metadata changes.`write`::Disable write operations. However, metadata changes are still allowed.====[discrete][[add-index-block-api-query-params]]==== {api-query-parms-title}include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=allow-no-indices]+Defaults to `true`.include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=expand-wildcards]+Defaults to `open`.include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=index-ignore-unavailable]include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=timeoutparms][discrete][[add-index-block-api-example]]==== {api-examples-title}The following example shows how to add an index block:[source,console]--------------------------------------------------PUT /my-index-000001/_block/write--------------------------------------------------// TEST[s/^/PUT my-index-000001\n/]The API returns following response:[source,console-result]--------------------------------------------------{  "acknowledged" : true,  "shards_acknowledged" : true,  "indices" : [ {    "name" : "my-index-000001",    "blocked" : true  } ]}--------------------------------------------------
 |