CAT APIs
Introduced 1.0
You can get essential statistics about your cluster in an easy-to-understand, tabular format using the compact and aligned text (CAT) API. The CAT API is a human-readable interface that returns plain text instead of traditional JSON.
Using the CAT API, you can answer questions like which node is the elected cluster manager, what state the cluster is in, how many documents are in each index, and so on.
Example
To see the available operations in the CAT API, use the following command:
GET /_catresponse = client.cat.help()The response is an ASCII cat (=^.^=) and a list of operations:
=^.^=
/_cat/allocation
/_cat/segment_replication
/_cat/segment_replication/{index}
/_cat/shards
/_cat/shards/{index}
/_cat/cluster_manager
/_cat/nodes
/_cat/tasks
/_cat/indices
/_cat/indices/{index}
/_cat/segments
/_cat/segments/{index}
/_cat/count
/_cat/count/{index}
/_cat/recovery
/_cat/recovery/{index}
/_cat/health
/_cat/pending_tasks
/_cat/aliases
/_cat/aliases/{alias}
/_cat/thread_pool
/_cat/thread_pool/{thread_pools}
/_cat/plugins
/_cat/fielddata
/_cat/fielddata/{fields}
/_cat/nodeattrs
/_cat/repositories
/_cat/snapshots/{repository}
/_cat/templates
/_cat/pit_segments
/_cat/pit_segments/{pit_id}
Optional query parameters
The root _cat API does not take any parameters, but individual APIs, such as /_cat/nodes accept the following query parameters.
| Parameter | Description | 
|---|---|
| v | Provides verbose output by adding headers to the columns. It also adds some formatting to help align each of the columns together. All examples in this section include the vparameter. | 
| help | Lists the default and other available headers for a given operation. | 
| h | Limits the output to specific headers. | 
| format | The format in which to return the result. Valid values are json,yaml,cbor, andsmile. | 
| s | Sorts the output by the specified columns. | 
Query parameter usage examples
You can specify a query parameter to any CAT operation to obtain more specific results.
Get verbose output
To query aliases and get verbose output that includes all column headings in the response, use the v query parameter.
GET /_cat/aliases?vresponse = client.cat.aliases(
  params = { "v": "true" }
)The response provides more details, such as names of each column in the response.
alias index filter routing.index routing.search is_write_index
.kibana .kibana_1 - - - -
sample-alias1 sample-index-1 - - - -
Without the verbose parameter, v, the response simply returns the alias names:
.kibana .kibana_1 - - - -
sample-alias1 sample-index-1 - - - -
Get all available headers
To see all the available headers, use the help parameter:
GET _cat/<operation_name>?help
For example, to see the available headers for the CAT aliases operation, send the following request:
GET /_cat/aliases?helpresponse = client.cat.aliases(
  params = { "help": "true" }
)The response contains the available headers:
alias          | a                | alias name
index          | i,idx            | index alias points to
filter         | f,fi             | filter
routing.index  | ri,routingIndex  | index routing
routing.search | rs,routingSearch | search routing
is_write_index | w,isWriteIndex   | write index
Get a subset of headers
To limit the output to a subset of headers, use the h parameter:
GET _cat/<operation_name>?h=<header_name_1>,<header_name_2>&v
For example, to limit aliases to only the alias name and index, send the following request:
GET /_cat/aliases?h=alias,indexresponse = client.cat.aliases(
  params = { "h": "alias,index" }
)The response contains the requested information:
.kibana .kibana_1
sample-alias1 sample-index-1
Typically, for any operation you can find out what headers are available using the help parameter, and then use the h parameter to limit the output to only the headers that you care about.
Sort by a header
To sort the output by a header, use the s parameter:
GET _cat/<operation_name>?s=<header_name_1>,<header_name_2>
For example, to sort aliases by alias and then index, send the following request:
GET /_cat/aliases?s=i,aresponse = client.cat.aliases(
  params = { "s": "i,a" }
)The response contains the requested information:
sample-alias2 sample-index-1
sample-alias1 sample-index-2
Retrieve data in JSON format
By default, CAT APIs return data in text/plain format.
To retrieve data in JSON format, use the format=json parameter:
GET _cat/<operation_name>?format=json
For example, to retrieve aliases in JSON format, send the following request:
GET /_cat/aliases?format=jsonresponse = client.cat.aliases(
  params = { "format": "json" }
)The response contains data in JSON format:
[
  {"alias":".kibana","index":".kibana_1","filter":"-","routing.index":"-","routing.search":"-","is_write_index":"-"},
  {"alias":"sample-alias-1","index":"sample-index-1","filter":"-","routing.index":"-","routing.search":"-","is_write_index":"-"}
]
Other supported formats are YAML, CBOR, and Smile.
CAT API operations
The following CAT API operations are available.
Cluster and node information
- CAT aliases
- CAT allocation
- CAT cluster manager
- CAT health
- CAT nodes
- CAT node attributes
- CAT pending tasks
- CAT plugins
- CAT repositories
- CAT tasks
- CAT templates
- CAT thread pool
Index and document information
- CAT count
- CAT field data
- CAT indices
- CAT PIT segments
- CAT recovery
- CAT segment replication
- CAT segments
- CAT shards
Snapshot information
If you use the Security plugin, make sure you have the appropriate permissions.