2017-04-04 12:33:22 -04:00
|
|
|
---
|
|
|
|
layout: api
|
|
|
|
page_title: Health - HTTP API
|
|
|
|
sidebar_current: api-health
|
|
|
|
description: |-
|
|
|
|
The /health endpoints query health-related information for services and checks
|
|
|
|
in Consul.
|
|
|
|
---
|
|
|
|
|
|
|
|
# Health HTTP Endpoint
|
|
|
|
|
|
|
|
The `/health` endpoints query health-related information. They are provided
|
|
|
|
separately from the `/catalog` endpoints since users may prefer not to use the
|
|
|
|
optional health checking mechanisms. Additionally, some of the query results
|
|
|
|
from the health endpoints are filtered while the catalog endpoints provide the
|
|
|
|
raw entries.
|
|
|
|
|
|
|
|
## List Checks for Node
|
|
|
|
|
|
|
|
This endpoint returns the checks specific to the node provided on the path.
|
|
|
|
|
|
|
|
| Method | Path | Produces |
|
|
|
|
| ------ | ---------------------------- | -------------------------- |
|
|
|
|
| `GET` | `/health/node/:node` | `application/json` |
|
|
|
|
|
|
|
|
The table below shows this endpoint's support for
|
|
|
|
[blocking queries](/api/index.html#blocking-queries),
|
|
|
|
[consistency modes](/api/index.html#consistency-modes), and
|
|
|
|
[required ACLs](/api/index.html#acls).
|
|
|
|
|
|
|
|
| Blocking Queries | Consistency Modes | ACL Required |
|
|
|
|
| ---------------- | ----------------- | ------------------------ |
|
|
|
|
| `YES` | `all` | `node:read,service:read` |
|
|
|
|
|
|
|
|
### Parameters
|
|
|
|
|
|
|
|
- `node` `(string: <required>)` - Specifies the name or ID of the node to query.
|
|
|
|
This is specified as part of the URL
|
|
|
|
|
|
|
|
- `dc` `(string: "")` - Specifies the datacenter to query. This will default to
|
|
|
|
the datacenter of the agent being queried. This is specified as part of the
|
|
|
|
URL as a query parameter.
|
|
|
|
|
|
|
|
### Sample Request
|
|
|
|
|
|
|
|
```text
|
|
|
|
$ curl \
|
2018-08-28 09:07:15 -07:00
|
|
|
http://127.0.0.1:8500/v1/health/node/my-node
|
2017-04-04 12:33:22 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
### Sample Response
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"ID": "40e4a748-2192-161a-0510-9bf59fe950b5",
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "serfHealth",
|
|
|
|
"Name": "Serf Health Status",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "",
|
2017-11-23 22:16:42 +01:00
|
|
|
"ServiceTags": []
|
2017-04-04 12:33:22 -04:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"ID": "40e4a748-2192-161a-0510-9bf59fe950b5",
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "service:redis",
|
|
|
|
"Name": "Service 'redis' check",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "redis",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "redis",
|
2018-08-28 09:07:15 -07:00
|
|
|
"ServiceTags": ["primary"]
|
2017-04-04 12:33:22 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
|
|
|
## List Checks for Service
|
|
|
|
|
|
|
|
This endpoint returns the checks associated with the service provided on the
|
|
|
|
path.
|
|
|
|
|
|
|
|
| Method | Path | Produces |
|
|
|
|
| ------ | ---------------------------- | -------------------------- |
|
|
|
|
| `GET` | `/health/checks/:service` | `application/json` |
|
|
|
|
|
|
|
|
The table below shows this endpoint's support for
|
|
|
|
[blocking queries](/api/index.html#blocking-queries),
|
|
|
|
[consistency modes](/api/index.html#consistency-modes), and
|
|
|
|
[required ACLs](/api/index.html#acls).
|
|
|
|
|
|
|
|
| Blocking Queries | Consistency Modes | ACL Required |
|
|
|
|
| ---------------- | ----------------- | ------------------------ |
|
|
|
|
| `YES` | `all` | `node:read,service:read` |
|
|
|
|
|
|
|
|
### Parameters
|
|
|
|
|
|
|
|
- `service` `(string: <required>)` - Specifies the service to list checks for.
|
|
|
|
This is provided as part of the URL.
|
|
|
|
|
|
|
|
- `dc` `(string: "")` - Specifies the datacenter to query. This will default to
|
|
|
|
the datacenter of the agent being queried. This is specified as part of the
|
|
|
|
URL as a query parameter.
|
|
|
|
|
|
|
|
- `near` `(string: "")` - Specifies a node name to sort the node list in
|
|
|
|
ascending order based on the estimated round trip time from that node. Passing
|
|
|
|
`?near=_agent` will use the agent's node for the sort. This is specified as
|
|
|
|
part of the URL as a query parameter.
|
|
|
|
|
|
|
|
- `node-meta` `(string: "")` - Specifies a desired node metadata key/value pair
|
|
|
|
of the form `key:value`. This parameter can be specified multiple times, and
|
|
|
|
will filter the results to nodes with the specified key/value pairs. This is
|
|
|
|
specified as part of the URL as a query parameter.
|
|
|
|
|
|
|
|
### Sample Request
|
|
|
|
|
|
|
|
```text
|
|
|
|
$ curl \
|
2018-08-28 09:07:15 -07:00
|
|
|
http://127.0.0.1:8500/v1/health/checks/my-service
|
2017-04-04 12:33:22 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
### Sample Response
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "service:redis",
|
|
|
|
"Name": "Service 'redis' check",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "redis",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "redis",
|
|
|
|
"ServiceTags": ["primary"]
|
2017-04-04 12:33:22 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
|
|
|
## List Nodes for Service
|
|
|
|
|
|
|
|
This endpoint returns the nodes providing the service indicated on the path.
|
|
|
|
Users can also build in support for dynamic load balancing and other features by
|
|
|
|
incorporating the use of health checks.
|
|
|
|
|
|
|
|
| Method | Path | Produces |
|
|
|
|
| ------ | ---------------------------- | -------------------------- |
|
|
|
|
| `GET` | `/health/service/:service` | `application/json` |
|
|
|
|
|
|
|
|
The table below shows this endpoint's support for
|
|
|
|
[blocking queries](/api/index.html#blocking-queries),
|
|
|
|
[consistency modes](/api/index.html#consistency-modes), and
|
|
|
|
[required ACLs](/api/index.html#acls).
|
|
|
|
|
|
|
|
| Blocking Queries | Consistency Modes | ACL Required |
|
|
|
|
| ---------------- | ----------------- | ------------------------ |
|
|
|
|
| `YES` | `all` | `node:read,service:read` |
|
|
|
|
|
|
|
|
### Parameters
|
|
|
|
|
|
|
|
- `service` `(string: <required>)` - Specifies the service to list services for.
|
|
|
|
This is provided as part of the URL.
|
|
|
|
|
|
|
|
- `dc` `(string: "")` - Specifies the datacenter to query. This will default to
|
|
|
|
the datacenter of the agent being queried. This is specified as part of the
|
|
|
|
URL as a query parameter.
|
|
|
|
|
|
|
|
- `near` `(string: "")` - Specifies a node name to sort the node list in
|
|
|
|
ascending order based on the estimated round trip time from that node. Passing
|
|
|
|
`?near=_agent` will use the agent's node for the sort. This is specified as
|
|
|
|
part of the URL as a query parameter.
|
|
|
|
|
2017-09-20 09:05:23 +02:00
|
|
|
- `tag` `(string: "")` - Specifies the tag to filter the list. This is
|
2017-04-04 12:33:22 -04:00
|
|
|
specifies as part of the URL as a query parameter.
|
|
|
|
|
|
|
|
- `node-meta` `(string: "")` - Specifies a desired node metadata key/value pair
|
|
|
|
of the form `key:value`. This parameter can be specified multiple times, and
|
|
|
|
will filter the results to nodes with the specified key/value pairs. This is
|
|
|
|
specified as part of the URL as a query parameter.
|
|
|
|
|
|
|
|
- `passing` `(bool: false)` - Specifies that the server should return only nodes
|
|
|
|
with all checks in the `passing` state. This can be used to avoid additional
|
|
|
|
filtering on the client side.
|
|
|
|
|
|
|
|
### Sample Request
|
|
|
|
|
|
|
|
```text
|
|
|
|
$ curl \
|
2018-08-28 09:07:15 -07:00
|
|
|
http://127.0.0.1:8500/v1/health/service/my-service
|
2017-04-04 12:33:22 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
### Sample Response
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"Node": {
|
|
|
|
"ID": "40e4a748-2192-161a-0510-9bf59fe950b5",
|
|
|
|
"Node": "foobar",
|
|
|
|
"Address": "10.1.10.12",
|
2017-04-18 05:02:24 -07:00
|
|
|
"Datacenter": "dc1",
|
2017-04-04 12:33:22 -04:00
|
|
|
"TaggedAddresses": {
|
|
|
|
"lan": "10.1.10.12",
|
|
|
|
"wan": "10.1.10.12"
|
|
|
|
},
|
|
|
|
"Meta": {
|
|
|
|
"instance_type": "t2.medium"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"Service": {
|
|
|
|
"ID": "redis",
|
|
|
|
"Service": "redis",
|
2017-04-27 16:03:05 -07:00
|
|
|
"Tags": ["primary"],
|
2017-04-04 12:33:22 -04:00
|
|
|
"Address": "10.1.10.12",
|
2018-03-28 09:04:50 -05:00
|
|
|
"Meta": {
|
2018-02-11 14:12:41 +01:00
|
|
|
"redis_version": "4.0"
|
|
|
|
},
|
2017-04-04 12:33:22 -04:00
|
|
|
"Port": 8000
|
|
|
|
},
|
|
|
|
"Checks": [
|
|
|
|
{
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "service:redis",
|
|
|
|
"Name": "Service 'redis' check",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "redis",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "redis",
|
|
|
|
"ServiceTags": ["primary"]
|
2017-04-04 12:33:22 -04:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "serfHealth",
|
|
|
|
"Name": "Serf Health Status",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "",
|
2017-11-23 22:16:42 +01:00
|
|
|
"ServiceTags": []
|
2017-04-04 12:33:22 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
2018-07-20 16:50:28 +01:00
|
|
|
## List Nodes for Connect-capable Service
|
|
|
|
|
|
|
|
This endpoint returns the nodes providing a
|
|
|
|
[Connect-capable](/docs/connect/index.html) service in a given datacenter.
|
|
|
|
This will include both proxies and native integrations. A service may
|
|
|
|
register both Connect-capable and incapable services at the same time,
|
|
|
|
so this endpoint may be used to filter only the Connect-capable endpoints.
|
|
|
|
|
|
|
|
| Method | Path | Produces |
|
|
|
|
| ------ | ---------------------------- | -------------------------- |
|
|
|
|
| `GET` | `/health/connect/:service` | `application/json` |
|
|
|
|
|
|
|
|
Parameters and response format are the same as
|
|
|
|
[`/health/service/:service`](/api/health.html#list-nodes-for-service).
|
|
|
|
|
2017-04-04 12:33:22 -04:00
|
|
|
## List Checks in State
|
|
|
|
|
|
|
|
This endpoint returns the checks in the state provided on the path.
|
|
|
|
|
|
|
|
| Method | Path | Produces |
|
|
|
|
| ------ | ---------------------------- | -------------------------- |
|
|
|
|
| `GET` | `/health/state/:state` | `application/json` |
|
|
|
|
|
|
|
|
The table below shows this endpoint's support for
|
|
|
|
[blocking queries](/api/index.html#blocking-queries),
|
|
|
|
[consistency modes](/api/index.html#consistency-modes), and
|
|
|
|
[required ACLs](/api/index.html#acls).
|
|
|
|
|
|
|
|
| Blocking Queries | Consistency Modes | ACL Required |
|
|
|
|
| ---------------- | ----------------- | ------------------------ |
|
|
|
|
| `YES` | `all` | `node:read,service:read` |
|
|
|
|
|
|
|
|
### Parameters
|
|
|
|
|
2018-03-19 12:56:00 -04:00
|
|
|
- `state` `(string: <required>)` - Specifies the state to query. Supported states
|
2017-04-04 12:33:22 -04:00
|
|
|
are `any`, `passing`, `warning`, or `critical`. The `any` state is a wildcard
|
|
|
|
that can be used to return all checks.
|
|
|
|
|
|
|
|
- `dc` `(string: "")` - Specifies the datacenter to query. This will default to
|
|
|
|
the datacenter of the agent being queried. This is specified as part of the
|
|
|
|
URL as a query parameter.
|
|
|
|
|
|
|
|
- `near` `(string: "")` - Specifies a node name to sort the node list in
|
|
|
|
ascending order based on the estimated round trip time from that node. Passing
|
|
|
|
`?near=_agent` will use the agent's node for the sort. This is specified as
|
|
|
|
part of the URL as a query parameter.
|
|
|
|
|
|
|
|
- `node-meta` `(string: "")` - Specifies a desired node metadata key/value pair
|
|
|
|
of the form `key:value`. This parameter can be specified multiple times, and
|
|
|
|
will filter the results to nodes with the specified key/value pairs. This is
|
|
|
|
specified as part of the URL as a query parameter.
|
|
|
|
|
|
|
|
### Sample Request
|
|
|
|
|
|
|
|
```text
|
|
|
|
$ curl \
|
2018-08-28 09:07:15 -07:00
|
|
|
http://127.0.0.1:8500/v1/health/state/passing
|
2017-04-04 12:33:22 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
### Sample Response
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "serfHealth",
|
|
|
|
"Name": "Serf Health Status",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "",
|
2017-11-23 22:16:42 +01:00
|
|
|
"ServiceTags": []
|
2017-04-04 12:33:22 -04:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"Node": "foobar",
|
|
|
|
"CheckID": "service:redis",
|
|
|
|
"Name": "Service 'redis' check",
|
|
|
|
"Status": "passing",
|
|
|
|
"Notes": "",
|
|
|
|
"Output": "",
|
|
|
|
"ServiceID": "redis",
|
2017-04-27 16:03:05 -07:00
|
|
|
"ServiceName": "redis",
|
2018-07-20 16:50:28 +01:00
|
|
|
"ServiceTags": ["primary"]
|
2017-04-04 12:33:22 -04:00
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|