[[indices-segments]] === Index segments API ++++ Index segments ++++ Returns low-level information about the https://lucene.apache.org/core/[Lucene] segments in index shards. For data streams, the API returns information about the stream's backing indices. [source,console] ---- GET /twitter/_segments ---- // TEST[setup:twitter] [[index-segments-api-request]] ==== {api-request-title} `GET //_segments` `GET /_segments` [[index-segments-api-path-params]] ==== {api-path-parms-title} ``:: (Optional, string) Comma-separated list of data streams, indices, and index aliases used to limit the request. Wildcard expressions (`*`) are supported. + To target all data streams and indices in a cluster, omit this parameter or use `_all` or `*`. [[index-segments-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] `verbose`:: experimental:[] (Optional, boolean) If `true`, the response includes detailed information about Lucene's memory usage. Defaults to `false`. [[index-segments-api-response-body]] ==== {api-response-body-title} ``:: (String) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=segment] `generation`:: (Integer) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=generation] `num_docs`:: (Integer) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=docs-count] `deleted_docs`:: (Integer) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=docs-deleted] `size_in_bytes`:: (Integer) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=segment-size] `memory_in_bytes`:: (Integer) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=memory] `committed`:: (Boolean) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=committed] `search`:: (Boolean) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=segment-search] `version`:: (String) include::{es-repo-dir}/rest-api/common-parms.asciidoc[tag=segment-version] `compound`:: (Boolean) If `true`, Lucene merged all files from the segment into a single file to save file descriptors. `attributes`:: (Object) Contains information about whether high compression was enabled. [[index-segments-api-example]] ==== {api-examples-title} ===== Get segment information for a specific data stream or index [source,console] -------------------------------------------------- GET /test/_segments -------------------------------------------------- // TEST[s/^/PUT test\n{"settings":{"number_of_shards":1, "number_of_replicas": 0}}\nPOST test\/test\?refresh\n{"test": "test"}\n/] ===== Get segment information for several data streams and indices [source,console] -------------------------------------------------- GET /test1,test2/_segments -------------------------------------------------- // TEST[s/^/PUT test1\nPUT test2\n/] ===== Get segment information for all data streams and indices in a cluster [source,console] -------------------------------------------------- GET /_segments -------------------------------------------------- // TEST[s/^/PUT test\n{"settings":{"number_of_shards":1, "number_of_replicas": 0}}\nPOST test\/test\?refresh\n{"test": "test"}\n/] The API returns the following response: [source,console-response] -------------------------------------------------- { "_shards": ... "indices": { "test": { "shards": { "0": [ { "routing": { "state": "STARTED", "primary": true, "node": "zDC_RorJQCao9xf9pg3Fvw" }, "num_committed_segments": 0, "num_search_segments": 1, "segments": { "_0": { "generation": 0, "num_docs": 1, "deleted_docs": 0, "size_in_bytes": 3800, "memory_in_bytes": 1410, "committed": false, "search": true, "version": "7.0.0", "compound": true, "attributes": { } } } } ] } } } } -------------------------------------------------- // TESTRESPONSE[s/"_shards": \.\.\./"_shards": $body._shards,/] // TESTRESPONSE[s/"node": "zDC_RorJQCao9xf9pg3Fvw"/"node": $body.$_path/] // TESTRESPONSE[s/"attributes": \{[^}]*\}/"attributes": $body.$_path/] // TESTRESPONSE[s/: (\-)?[0-9]+/: $body.$_path/] // TESTRESPONSE[s/7\.0\.0/$body.$_path/] ===== Verbose mode To add additional information that can be used for debugging, use the `verbose` flag. experimental::[] [source,console] -------------------------------------------------- GET /test/_segments?verbose=true -------------------------------------------------- // TEST[continued] The API returns the following response: [source,console-response] -------------------------------------------------- { ... "_0": { ... "ram_tree": [ { "description": "postings [PerFieldPostings(format=1)]", "size_in_bytes": 2696, "children": [ { "description": "format 'Lucene50_0' ...", "size_in_bytes": 2608, "children" :[ ... ] }, ... ] }, ... ] } ... } -------------------------------------------------- // TESTRESPONSE[skip:Response is too verbose to be fully shown in documentation, so we just show the relevant bit and don't test the response.]