Link Search Menu Expand Document Documentation Menu

CAT API

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 master, what state is the cluster 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 _cat

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 v parameter.
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, and smile.
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?v

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?help

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,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,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=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.

If you use the Security plugin, make sure you have the appropriate permissions.


Related articles