2014-04-10 17:41:49 -07:00
---
layout: "intro"
page_title: "Registering Health Checks"
sidebar_current: "gettingstarted-checks"
2014-10-19 19:40:10 -04:00
description: |-
2015-03-17 17:50:28 -04:00
We've now seen how simple it is to run Consul, add nodes and services, and query those nodes and services. In this step, we will continue our tour by adding health checks to both nodes and services. Health checks are a critical component of service discovery that prevent using services that are unhealthy.
2014-04-10 17:41:49 -07:00
---
2014-04-14 14:00:53 -07:00
# Health Checks
2014-04-10 17:41:49 -07:00
2014-04-14 14:00:53 -07:00
We've now seen how simple it is to run Consul, add nodes and services, and
2015-02-20 18:10:58 -05:00
query those nodes and services. In this section, we will continue our tour
by adding health checks to both nodes and services. Health checks are a
2015-03-17 17:50:28 -04:00
critical component of service discovery that prevent using services that
2015-02-20 18:10:58 -05:00
are unhealthy.
2014-04-14 14:00:53 -07:00
2015-03-17 17:50:28 -04:00
This step builds upon [the Consul cluster created previously ](join.html ).
At this point, you should have a two-node cluster running.
2014-04-10 19:06:10 -07:00
## Defining Checks
2015-02-20 18:10:58 -05:00
Similar to a service, a check can be registered either by providing a
[check definition ](/docs/agent/checks.html ) or by making the
2015-03-17 17:50:28 -04:00
appropriate calls to the [HTTP API ](/docs/agent/http/health.html ).
2014-04-14 14:00:53 -07:00
2015-03-17 17:50:28 -04:00
We will use the check definition approach because, just like with
services, definitions are the most common way to set up checks.
2014-04-14 14:00:53 -07:00
2015-02-20 18:16:31 -05:00
Create two definition files in the Consul configuration directory of
2015-02-20 18:10:58 -05:00
the second node:
2014-04-10 19:06:10 -07:00
2014-10-19 19:40:10 -04:00
```text
2015-03-17 17:50:28 -04:00
vagrant@n2: ~$ echo '{"check": {"name": "ping", \
"script": "ping -c1 google.com >/dev/null", "interval": "30s"}}' \
>/etc/consul.d/ping.json
2014-04-10 19:06:10 -07:00
2015-03-17 17:50:28 -04:00
vagrant@n2: ~$ echo '{"service": {"name": "web", "tags": ["rails"], "port": 80,\
"check": {"script": "curl localhost >/dev/null 2>& 1", "interval": "10s"}}}' \
>/etc/consul.d/web.json
2014-04-10 19:06:10 -07:00
```
2014-04-14 14:00:53 -07:00
The first definition adds a host-level check named "ping". This check runs
2015-06-15 21:55:05 -05:00
on a 30 second interval, invoking `ping -c1 google.com` . On a `script` -based
health check, the check runs as the same user that started the Consul process.
If the command exits with a non-zero exit code, then the node will be flagged
unhealthy. This is the contract for any `script` -based health check.
2014-04-14 14:00:53 -07:00
2015-02-20 18:10:58 -05:00
The second command modifies the service named `web` , adding a check that sends a
request every 10 seconds via curl to verify that the web server is accessible.
As with the host-level health check, if the script exits with a non-zero exit code,
the service will be flagged unhealthy.
2014-04-10 19:06:10 -07:00
2015-03-17 17:50:28 -04:00
Now, restart the second agent or send it a `SIGHUP` signal. You should see the
2014-04-14 14:00:53 -07:00
following log lines:
2014-04-10 19:06:10 -07:00
2014-10-19 19:40:10 -04:00
```text
2014-04-10 19:06:10 -07:00
==> Starting Consul agent...
...
[INFO] agent: Synced service 'web'
[INFO] agent: Synced check 'service:web'
[INFO] agent: Synced check 'ping'
[WARN] Check 'service:web' is now critical
```
2015-03-17 17:50:28 -04:00
The first few lines indicate that the agent has synced the new
2014-04-14 14:00:53 -07:00
definitions. The last line indicates that the check we added for
the `web` service is critical. This is because we're not actually running
2015-02-20 18:10:58 -05:00
a web server, so the curl test is failing!
2014-04-10 19:06:10 -07:00
## Checking Health Status
2015-02-20 18:10:58 -05:00
Now that we've added some simple checks, we can use the HTTP API to inspect
them. First, we can look for any failing checks using this command (note, this
can be run on either node):
2014-04-10 19:06:10 -07:00
2014-10-19 19:40:10 -04:00
```text
2015-03-17 17:50:28 -04:00
vagrant@n1: ~$ curl http://localhost:8500/v1/health/state/critical
2014-04-10 19:06:10 -07:00
[{"Node":"agent-two","CheckID":"service:web","Name":"Service 'web' check","Status":"critical","Notes":"","ServiceID":"web","ServiceName":"web"}]
```
2015-02-20 18:10:58 -05:00
We can see that there is only a single check, our `web` service check, in the
`critical` state.
2014-04-14 14:00:53 -07:00
Additionally, we can attempt to query the web service using DNS. Consul
2015-02-20 18:10:58 -05:00
will not return any results since the service is unhealthy:
2014-04-10 19:06:10 -07:00
2014-10-19 19:40:10 -04:00
```text
dig @127 .0.0.1 -p 8600 web.service.consul
2014-04-14 14:00:53 -07:00
...
2014-04-10 19:06:10 -07:00
;; QUESTION SECTION:
;web.service.consul. IN A
```
2015-03-17 17:50:28 -04:00
## Next Steps
2015-02-20 18:10:58 -05:00
In this section, you learned how easy it is to add health checks. Check definitions
2014-04-10 19:06:10 -07:00
can be updated by changing configuration files and sending a `SIGHUP` to the agent.
2015-02-20 18:16:31 -05:00
Alternatively, the HTTP API can be used to add, remove, and modify checks dynamically.
2015-03-17 17:50:28 -04:00
The API also allows for a "dead man's switch", a
[TTL-based check ](/docs/agent/checks.html#TTL ). TTL checks can be used to integrate an
application more tightly with Consul, enabling business logic to be evaluated as part
of assessing the state of the check.
Next, we will explore [Consul's K/V store ](kv.html ).