Nodes info API

Returns cluster nodes information.

Request

GET /_nodes

GET /_nodes/<node_id>

GET /_nodes/<metric>

GET /_nodes/<node_id>/<metric>

Description

The cluster nodes info API allows to retrieve one or more (or all) of the cluster nodes information. All the nodes selective options are explained here.

By default, it returns all attributes and core settings for a node.

Path parameters

<metric>

(Optional, string) Limits the information returned to the specific metrics. A comma-separated list of the following options:

  • http

    HTTP connection information.

    ingest

    Statistics about ingest preprocessing.

    jvm

    JVM stats, memory pool information, garbage collection, buffer pools, number of loaded/unloaded classes.

    os

    Operating system stats, load average, mem, swap.

    plugins

    Details about the installed plugins and modules per node. The following information are available for each plugin and module:


    • name: plugin name
    • version: version of Elasticsearch the plugin was built for
    • description: short description of the plugin’s purpose
    • classname: fully-qualified class name of the plugin’s entry point
    • has_native_controller: whether or not the plugin has a native controller process —-

    process

    Process statistics, memory consumption, cpu usage, open file descriptors.

    settings

    thread_pool

    Statistics about each thread pool, including current size, queue and rejected tasks

    transport

    Transport statistics about sent and received bytes in cluster communication.

<node_id>

(Optional, string) Comma-separated list of node IDs or names used to limit returned information.

Response body

build_hash

Short hash of the last git commit in this release.

host

The node’s host name.

ip

The node’s IP address.

name

The node’s name.

total_indexing_buffer

Total heap allowed to be used to hold recently indexed documents before they must be written to disk. This size is a shared pool across all shards on this node, and is controlled by Indexing Buffer settings.

total_indexing_buffer_in_bytes

Same as total_indexing_buffer, but expressed in bytes.

transport_address

Host and port where transport HTTP connections are accepted.

version

Elasticsearch version running on this node.

The os flag can be set to retrieve information that concern the operating system:

os.refresh_interval_in_millis

Refresh interval for the OS statistics

os.name

Name of the operating system (ex: Linux, Windows, Mac OS X)

os.arch

Name of the JVM architecture (ex: amd64, x86)

os.version

Version of the operating system

os.available_processors

Number of processors available to the Java virtual machine

os.allocated_processors

The number of processors actually used to calculate thread pool size. This number can be set with the node.processors setting of a node and defaults to the number of processors reported by the OS.

The process flag can be set to retrieve information that concern the current running process:

process.refresh_interval_in_millis

Refresh interval for the process statistics

process.id

Process identifier (PID)

process.mlockall

Indicates if the process address space has been successfully locked in memory

Query parameters

flat_settings

(Optional, boolean) If true, returns settings in flat format. Defaults to false.

master_timeout

(Optional, time units) Specifies the period of time to wait for a connection to the master node. If no response is received before the timeout expires, the request fails and returns an error. Defaults to 30s.

timeout

(Optional, time units) Specifies the period of time to wait for a response. If no response is received before the timeout expires, the request fails and returns an error. Defaults to 30s.

Examples

  1. # return just process
  2. GET /_nodes/process
  3. # same as above
  4. GET /_nodes/_all/process
  5. # return just jvm and process of only nodeId1 and nodeId2
  6. GET /_nodes/nodeId1,nodeId2/jvm,process
  7. # same as above
  8. GET /_nodes/nodeId1,nodeId2/info/jvm,process
  9. # return all the information of only nodeId1 and nodeId2
  10. GET /_nodes/nodeId1,nodeId2/_all

The _all flag can be set to return all the information - or you can omit it.

Example for plugins metric

If plugins is specified, the result will contain details about the installed plugins and modules:

  1. GET /_nodes/plugins

The API returns the following response:

  1. {
  2. "_nodes": ...
  3. "cluster_name": "elasticsearch",
  4. "nodes": {
  5. "USpTGYaBSIKbgSUJR2Z9lg": {
  6. "name": "node-0",
  7. "transport_address": "192.168.17:9300",
  8. "host": "node-0.elastic.co",
  9. "ip": "192.168.17",
  10. "version": "{version}",
  11. "build_flavor": "{build_flavor}",
  12. "build_type": "{build_type}",
  13. "build_hash": "587409e",
  14. "roles": [
  15. "master",
  16. "data",
  17. "ingest"
  18. ],
  19. "attributes": {},
  20. "plugins": [
  21. {
  22. "name": "analysis-icu",
  23. "version": "{version}",
  24. "description": "The ICU Analysis plugin integrates Lucene ICU module into elasticsearch, adding ICU relates analysis components.",
  25. "classname": "org.elasticsearch.plugin.analysis.icu.AnalysisICUPlugin",
  26. "has_native_controller": false
  27. }
  28. ],
  29. "modules": [
  30. {
  31. "name": "lang-painless",
  32. "version": "{version}",
  33. "description": "An easy, safe and fast scripting language for Elasticsearch",
  34. "classname": "org.elasticsearch.painless.PainlessPlugin",
  35. "has_native_controller": false
  36. }
  37. ]
  38. }
  39. }
  40. }

Example for ingest metric

If ingest is specified, the response contains details about the available processors per node:

  1. GET /_nodes/ingest

The API returns the following response:

  1. {
  2. "_nodes": ...
  3. "cluster_name": "elasticsearch",
  4. "nodes": {
  5. "USpTGYaBSIKbgSUJR2Z9lg": {
  6. "name": "node-0",
  7. "transport_address": "192.168.17:9300",
  8. "host": "node-0.elastic.co",
  9. "ip": "192.168.17",
  10. "version": "{version}",
  11. "build_flavor": "{build_flavor}",
  12. "build_type": "{build_type}",
  13. "build_hash": "587409e",
  14. "roles": [],
  15. "attributes": {},
  16. "ingest": {
  17. "processors": [
  18. {
  19. "type": "date"
  20. },
  21. {
  22. "type": "uppercase"
  23. },
  24. {
  25. "type": "set"
  26. },
  27. {
  28. "type": "lowercase"
  29. },
  30. {
  31. "type": "gsub"
  32. },
  33. {
  34. "type": "convert"
  35. },
  36. {
  37. "type": "remove"
  38. },
  39. {
  40. "type": "fail"
  41. },
  42. {
  43. "type": "foreach"
  44. },
  45. {
  46. "type": "split"
  47. },
  48. {
  49. "type": "trim"
  50. },
  51. {
  52. "type": "rename"
  53. },
  54. {
  55. "type": "join"
  56. },
  57. {
  58. "type": "append"
  59. }
  60. ]
  61. }
  62. }
  63. }
  64. }