index-modules.asciidoc 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. [[index-modules]]
  2. = Index modules
  3. [partintro]
  4. --
  5. Index Modules are modules created per index and control all aspects related to
  6. an index.
  7. [float]
  8. [[index-modules-settings]]
  9. == Index Settings
  10. Index level settings can be set per-index. Settings may be:
  11. _static_::
  12. They can only be set at index creation time or on a
  13. <<indices-open-close,closed index>>.
  14. _dynamic_::
  15. They can be changed on a live index using the
  16. <<indices-update-settings,update-index-settings>> API.
  17. WARNING: Changing static or dynamic index settings on a closed index could
  18. result in incorrect settings that are impossible to rectify without deleting
  19. and recreating the index.
  20. [float]
  21. === Static index settings
  22. Below is a list of all _static_ index settings that are not associated with any
  23. specific index module:
  24. `index.number_of_shards`::
  25. The number of primary shards that an index should have. Defaults to 1.
  26. This setting can only be set at index creation time. It cannot be
  27. changed on a closed index. Note: the number of shards are limited to `1024` per
  28. index. This limitation is a safety limit to prevent accidental creation of indices
  29. that can destabilize a cluster due to resource allocation. The limit can be modified
  30. by specifying `export ES_JAVA_OPTS="-Des.index.max_number_of_shards=128"` system property on every node that is
  31. part of the cluster.
  32. `index.shard.check_on_startup`::
  33. Whether or not shards should be checked for corruption before opening. When
  34. corruption is detected, it will prevent the shard from being opened.
  35. Accepts:
  36. `false`::: (default) Don't check for corruption when opening a shard.
  37. `checksum`::: Check for physical corruption.
  38. `true`::: Check for both physical and logical corruption. This is much more
  39. expensive in terms of CPU and memory usage.
  40. +
  41. WARNING: Expert only. Checking shards may take a lot of time on large
  42. indices.
  43. [[index-codec]] `index.codec`::
  44. The +default+ value compresses stored data with LZ4
  45. compression, but this can be set to +best_compression+
  46. which uses https://en.wikipedia.org/wiki/DEFLATE[DEFLATE] for a higher
  47. compression ratio, at the expense of slower stored fields performance.
  48. If you are updating the compression type, the new one will be applied
  49. after segments are merged. Segment merging can be forced using
  50. <<indices-forcemerge,force merge>>.
  51. [[routing-partition-size]] `index.routing_partition_size`::
  52. The number of shards a custom <<mapping-routing-field,routing>> value can go to.
  53. Defaults to 1 and can only be set at index creation time. This value must be less
  54. than the `index.number_of_shards` unless the `index.number_of_shards` value is also 1.
  55. See <<routing-index-partition>> for more details about how this setting is used.
  56. [[load-fixed-bitset-filters-eagerly]] `index.load_fixed_bitset_filters_eagerly`::
  57. Indicates whether <<query-filter-context, cached filters>> are pre-loaded for
  58. nested queries. Possible values are `true` (default) and `false`.
  59. [[index-hidden]] `index.hidden`::
  60. Indicates whether the index should be hidden by default. Hidden indices are not
  61. returned by default when using a wildcard expression. This behavior is controlled
  62. per request through the use of the `expand_wildcards` parameter. Possible values are
  63. `true` and `false` (default).
  64. [float]
  65. [[dynamic-index-settings]]
  66. === Dynamic index settings
  67. Below is a list of all _dynamic_ index settings that are not associated with any
  68. specific index module:
  69. `index.number_of_replicas`::
  70. The number of replicas each primary shard has. Defaults to 1.
  71. `index.auto_expand_replicas`::
  72. Auto-expand the number of replicas based on the number of data nodes in the cluster.
  73. Set to a dash delimited lower and upper bound (e.g. `0-5`) or use `all`
  74. for the upper bound (e.g. `0-all`). Defaults to `false` (i.e. disabled).
  75. Note that the auto-expanded number of replicas only takes
  76. <<shard-allocation-filtering,allocation filtering>> rules into account, but ignores
  77. any other allocation rules such as <<allocation-awareness,shard allocation awareness>>
  78. and <<allocation-total-shards,total shards per node>>, and this can lead to the
  79. cluster health becoming `YELLOW` if the applicable rules prevent all the replicas
  80. from being allocated.
  81. `index.search.idle.after`::
  82. How long a shard can not receive a search or get request until it's considered
  83. search idle. (default is `30s`)
  84. [[index-refresh-interval-setting]]
  85. `index.refresh_interval`::
  86. How often to perform a refresh operation, which makes recent changes to the
  87. index visible to search. Defaults to `1s`. Can be set to `-1` to disable
  88. refresh. If this setting is not explicitly set, shards that haven't seen
  89. search traffic for at least `index.search.idle.after` seconds will not receive
  90. background refreshes until they receive a search request. Searches that hit an
  91. idle shard where a refresh is pending will wait for the next background
  92. refresh (within `1s`). This behavior aims to automatically optimize bulk
  93. indexing in the default case when no searches are performed. In order to opt
  94. out of this behavior an explicit value of `1s` should set as the refresh
  95. interval.
  96. `index.max_result_window`::
  97. The maximum value of `from + size` for searches to this index. Defaults to
  98. `10000`. Search requests take heap memory and time proportional to
  99. `from + size` and this limits that memory. See
  100. <<request-body-search-scroll,Scroll>> or <<request-body-search-search-after,Search After>> for a more efficient alternative
  101. to raising this.
  102. `index.max_inner_result_window`::
  103. The maximum value of `from + size` for inner hits definition and top hits aggregations to this index. Defaults to
  104. `100`. Inner hits and top hits aggregation take heap memory and time proportional to `from + size` and this limits that memory.
  105. `index.max_rescore_window`::
  106. The maximum value of `window_size` for `rescore` requests in searches of this index.
  107. Defaults to `index.max_result_window` which defaults to `10000`. Search
  108. requests take heap memory and time proportional to
  109. `max(window_size, from + size)` and this limits that memory.
  110. `index.max_docvalue_fields_search`::
  111. The maximum number of `docvalue_fields` that are allowed in a query.
  112. Defaults to `100`. Doc-value fields are costly since they might incur
  113. a per-field per-document seek.
  114. `index.max_script_fields`::
  115. The maximum number of `script_fields` that are allowed in a query.
  116. Defaults to `32`.
  117. [[index-max-ngram-diff]]
  118. `index.max_ngram_diff`::
  119. The maximum allowed difference between min_gram and max_gram for NGramTokenizer and NGramTokenFilter.
  120. Defaults to `1`.
  121. `index.max_shingle_diff`::
  122. The maximum allowed difference between max_shingle_size and min_shingle_size for ShingleTokenFilter.
  123. Defaults to `3`.
  124. `index.blocks.read_only`::
  125. Set to `true` to make the index and index metadata read only, `false` to
  126. allow writes and metadata changes.
  127. `index.blocks.read_only_allow_delete`::
  128. Similar to `index.blocks.read_only` but also allows deleting the index to
  129. free up resources. The <<disk-allocator,disk-based shard allocator>> may
  130. add and remove this block automatically.
  131. `index.blocks.read`::
  132. Set to `true` to disable read operations against the index.
  133. `index.blocks.write`::
  134. Set to `true` to disable data write operations against the index. Unlike `read_only`,
  135. this setting does not affect metadata. For instance, you can close an index with a `write`
  136. block, but not an index with a `read_only` block.
  137. `index.blocks.metadata`::
  138. Set to `true` to disable index metadata reads and writes.
  139. `index.max_refresh_listeners`::
  140. Maximum number of refresh listeners available on each shard of the index.
  141. These listeners are used to implement <<docs-refresh,`refresh=wait_for`>>.
  142. `index.analyze.max_token_count`::
  143. The maximum number of tokens that can be produced using _analyze API.
  144. Defaults to `10000`.
  145. `index.highlight.max_analyzed_offset`::
  146. The maximum number of characters that will be analyzed for a highlight request.
  147. This setting is only applicable when highlighting is requested on a text that was indexed without offsets or term vectors.
  148. Defaults to `1000000`.
  149. [[index-max-terms-count]]
  150. `index.max_terms_count`::
  151. The maximum number of terms that can be used in Terms Query.
  152. Defaults to `65536`.
  153. [[index-max-regex-length]]
  154. `index.max_regex_length`::
  155. The maximum length of regex that can be used in Regexp Query.
  156. Defaults to `1000`.
  157. `index.routing.allocation.enable`::
  158. Controls shard allocation for this index. It can be set to:
  159. * `all` (default) - Allows shard allocation for all shards.
  160. * `primaries` - Allows shard allocation only for primary shards.
  161. * `new_primaries` - Allows shard allocation only for newly-created primary shards.
  162. * `none` - No shard allocation is allowed.
  163. `index.routing.rebalance.enable`::
  164. Enables shard rebalancing for this index. It can be set to:
  165. * `all` (default) - Allows shard rebalancing for all shards.
  166. * `primaries` - Allows shard rebalancing only for primary shards.
  167. * `replicas` - Allows shard rebalancing only for replica shards.
  168. * `none` - No shard rebalancing is allowed.
  169. `index.gc_deletes`::
  170. The length of time that a <<delete-versioning,deleted document's version number>> remains available for <<index-versioning,further versioned operations>>.
  171. Defaults to `60s`.
  172. `index.default_pipeline`::
  173. The default <<ingest,ingest node>> pipeline for this index. Index requests will fail
  174. if the default pipeline is set and the pipeline does not exist. The default may be
  175. overridden using the `pipeline` parameter. The special pipeline name `_none` indicates
  176. no ingest pipeline should be run.
  177. `index.final_pipeline`::
  178. The final <<ingest,ingest node>> pipeline for this index. Index requests
  179. will fail if the final pipeline is set and the pipeline does not exist.
  180. The final pipeline always runs after the request pipeline (if specified) and
  181. the default pipeline (if it exists). The special pipeline name `_none`
  182. indicates no ingest pipeline will run.
  183. [float]
  184. === Settings in other index modules
  185. Other index settings are available in index modules:
  186. <<analysis,Analysis>>::
  187. Settings to define analyzers, tokenizers, token filters and character
  188. filters.
  189. <<index-modules-allocation,Index shard allocation>>::
  190. Control over where, when, and how shards are allocated to nodes.
  191. <<index-modules-mapper,Mapping>>::
  192. Enable or disable dynamic mapping for an index.
  193. <<index-modules-merge,Merging>>::
  194. Control over how shards are merged by the background merge process.
  195. <<index-modules-similarity,Similarities>>::
  196. Configure custom similarity settings to customize how search results are
  197. scored.
  198. <<index-modules-slowlog,Slowlog>>::
  199. Control over how slow queries and fetch requests are logged.
  200. <<index-modules-store,Store>>::
  201. Configure the type of filesystem used to access shard data.
  202. <<index-modules-translog,Translog>>::
  203. Control over the transaction log and background flush operations.
  204. <<index-modules-history-retention,History retention>>::
  205. Control over the retention of a history of operations in the index.
  206. [float]
  207. [[x-pack-index-settings]]
  208. === [xpack]#{xpack} index settings#
  209. <<ilm-settings,{ilm-cap}>>::
  210. Specify the lifecycle policy and rollover alias for an index.
  211. --
  212. include::index-modules/analysis.asciidoc[]
  213. include::index-modules/allocation.asciidoc[]
  214. include::index-modules/mapper.asciidoc[]
  215. include::index-modules/merge.asciidoc[]
  216. include::index-modules/similarity.asciidoc[]
  217. include::index-modules/slowlog.asciidoc[]
  218. include::index-modules/store.asciidoc[]
  219. include::index-modules/translog.asciidoc[]
  220. include::index-modules/history-retention.asciidoc[]
  221. include::index-modules/index-sorting.asciidoc[]