2014-02-07 16:41:03 -08:00
|
|
|
---
|
|
|
|
layout: "intro"
|
|
|
|
page_title: "Run the Agent"
|
|
|
|
sidebar_current: "gettingstarted-agent"
|
2015-12-27 09:45:59 -06:00
|
|
|
description: >
|
|
|
|
The Consul agent can run in either server or client mode. Each datacenter
|
|
|
|
must have at least one server, though a cluster of 3 or 5 servers is
|
|
|
|
recommended. A single server deployment is highly discouraged in production
|
|
|
|
as data loss is inevitable in a failure scenario.
|
2014-02-07 16:41:03 -08:00
|
|
|
---
|
|
|
|
|
2014-04-10 17:41:49 -07:00
|
|
|
# Run the Consul Agent
|
|
|
|
|
2014-11-26 11:37:28 +00:00
|
|
|
After Consul is installed, the agent must be run. The agent can run either
|
2015-02-19 17:32:31 -05:00
|
|
|
in server or client mode. Each datacenter must have at least one server,
|
2015-03-02 08:50:13 -05:00
|
|
|
though a cluster of 3 or 5 servers is recommended. A single server deployment
|
|
|
|
is _**highly**_ discouraged as data loss is inevitable in a failure scenario.
|
2015-02-19 17:12:56 -05:00
|
|
|
|
2015-03-02 08:50:13 -05:00
|
|
|
All other agents run in client mode. A client is a very lightweight
|
2015-02-19 17:12:56 -05:00
|
|
|
process that registers services, runs health checks, and forwards queries to
|
|
|
|
servers. The agent must be run on every node that is part of the cluster.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2015-03-02 08:50:13 -05:00
|
|
|
For more detail on bootstrapping a datacenter, see
|
|
|
|
[this guide](/docs/guides/bootstrapping.html).
|
|
|
|
|
2014-02-07 16:41:03 -08:00
|
|
|
## Starting the Agent
|
|
|
|
|
2015-12-27 09:45:59 -06:00
|
|
|
For simplicity, we'll start the Consul agent in development mode for now. This
|
|
|
|
mode is useful for bringing up a single-node Consul environment quickly and
|
|
|
|
easily. It is **not** intended to be used in production as it does not persist
|
|
|
|
any state.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2014-10-19 19:40:10 -04:00
|
|
|
```text
|
2016-01-05 09:48:04 -08:00
|
|
|
$ consul agent -dev
|
2014-04-10 17:41:49 -07:00
|
|
|
==> Starting Consul agent...
|
|
|
|
==> Starting Consul agent RPC...
|
|
|
|
==> Consul agent running!
|
2015-12-27 09:45:59 -06:00
|
|
|
Node name: 'Armons-MacBook-Air'
|
|
|
|
Datacenter: 'dc1'
|
|
|
|
Server: true (bootstrap: false)
|
|
|
|
Client Addr: 127.0.0.1 (HTTP: 8500, HTTPS: -1, DNS: 8600, RPC: 8400)
|
|
|
|
Cluster Addr: 172.20.20.11 (LAN: 8301, WAN: 8302)
|
|
|
|
Gossip encrypt: false, RPC-TLS: false, TLS-Incoming: false
|
|
|
|
Atlas: <disabled>
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
==> Log data will now stream in as it occurs:
|
|
|
|
|
2015-12-27 09:45:59 -06:00
|
|
|
[INFO] raft: Node at 172.20.20.11:8300 [Follower] entering Follower state
|
|
|
|
[INFO] serf: EventMemberJoin: Armons-MacBook-Air 172.20.20.11
|
|
|
|
[INFO] consul: adding LAN server Armons-MacBook-Air (Addr: 172.20.20.11:8300) (DC: dc1)
|
|
|
|
[INFO] serf: EventMemberJoin: Armons-MacBook-Air.dc1 172.20.20.11
|
|
|
|
[INFO] consul: adding WAN server Armons-MacBook-Air.dc1 (Addr: 172.20.20.11:8300) (DC: dc1)
|
|
|
|
[ERR] agent: failed to sync remote state: No cluster leader
|
2014-04-10 17:41:49 -07:00
|
|
|
[WARN] raft: Heartbeat timeout reached, starting election
|
2015-12-27 09:45:59 -06:00
|
|
|
[INFO] raft: Node at 172.20.20.11:8300 [Candidate] entering Candidate state
|
|
|
|
[DEBUG] raft: Votes needed: 1
|
|
|
|
[DEBUG] raft: Vote granted. Tally: 1
|
2014-04-10 17:41:49 -07:00
|
|
|
[INFO] raft: Election won. Tally: 1
|
2015-12-27 09:45:59 -06:00
|
|
|
[INFO] raft: Node at 172.20.20.11:8300 [Leader] entering Leader state
|
|
|
|
[INFO] raft: Disabling EnableSingleNode (bootstrap)
|
2014-04-10 17:41:49 -07:00
|
|
|
[INFO] consul: cluster leadership acquired
|
2015-12-27 09:45:59 -06:00
|
|
|
[DEBUG] raft: Node 172.20.20.11:8300 updated peer set (2): [172.20.20.11:8300]
|
|
|
|
[DEBUG] consul: reset tombstone GC to index 2
|
2014-04-10 17:41:49 -07:00
|
|
|
[INFO] consul: New leader elected: Armons-MacBook-Air
|
|
|
|
[INFO] consul: member 'Armons-MacBook-Air' joined, marking health alive
|
2015-12-27 09:45:59 -06:00
|
|
|
[INFO] agent: Synced service 'consul'
|
2014-02-07 16:41:03 -08:00
|
|
|
```
|
|
|
|
|
2014-04-10 17:41:49 -07:00
|
|
|
As you can see, the Consul agent has started and has output some log
|
2015-02-19 17:12:56 -05:00
|
|
|
data. From the log data, you can see that our agent is running in server mode
|
2014-04-10 17:41:49 -07:00
|
|
|
and has claimed leadership of the cluster. Additionally, the local member has
|
|
|
|
been marked as a healthy member of the cluster.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2014-10-19 19:40:10 -04:00
|
|
|
~> **Note for OS X Users:** Consul uses your hostname as the
|
2014-04-17 12:20:51 -04:00
|
|
|
default node name. If your hostname contains periods, DNS queries to
|
|
|
|
that node will not work with Consul. To avoid this, explicitly set
|
2014-10-19 19:40:10 -04:00
|
|
|
the name of your node with the `-node` flag.
|
2014-04-17 12:17:54 -04:00
|
|
|
|
2014-02-07 16:41:03 -08:00
|
|
|
## Cluster Members
|
|
|
|
|
2015-03-02 08:50:13 -05:00
|
|
|
If you run [`consul members`](/docs/commands/members.html) in another terminal, you
|
|
|
|
can see the members of the Consul cluster. We'll cover joining clusters in the next
|
|
|
|
section, but for now, you should only see one member (yourself):
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2014-10-19 19:40:10 -04:00
|
|
|
```text
|
2014-04-10 17:41:49 -07:00
|
|
|
$ consul members
|
2015-12-27 09:45:59 -06:00
|
|
|
Node Address Status Type Build Protocol DC
|
|
|
|
Armons-MacBook-Air 172.20.20.11:8301 alive server 0.6.1dev 2 dc1
|
2014-02-07 16:41:03 -08:00
|
|
|
```
|
|
|
|
|
2014-04-14 12:22:03 -07:00
|
|
|
The output shows our own node, the address it is running on, its
|
2015-02-19 17:12:56 -05:00
|
|
|
health state, its role in the cluster, and some version information.
|
2014-07-01 15:02:26 -07:00
|
|
|
Additional metadata can be viewed by providing the `-detailed` flag.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2015-03-02 08:50:13 -05:00
|
|
|
The output of the [`members`](/docs/commands/members.html) command is based on
|
|
|
|
the [gossip protocol](/docs/internals/gossip.html) and is eventually consistent.
|
2015-02-19 17:12:56 -05:00
|
|
|
That is, at any point in time, the view of the world as seen by your local
|
|
|
|
agent may not exactly match the state on the servers. For a strongly consistent
|
2015-02-19 17:18:58 -05:00
|
|
|
view of the world, use the [HTTP API](/docs/agent/http.html) as it forwards the
|
|
|
|
request to the Consul servers:
|
2014-04-10 17:41:49 -07:00
|
|
|
|
2014-10-19 19:40:10 -04:00
|
|
|
```text
|
2014-04-10 17:41:49 -07:00
|
|
|
$ curl localhost:8500/v1/catalog/nodes
|
2015-12-27 09:45:59 -06:00
|
|
|
[{"Node":"Armons-MacBook-Air","Address":"172.20.20.11","CreateIndex":3,"ModifyIndex":4}]
|
2014-04-10 17:41:49 -07:00
|
|
|
```
|
|
|
|
|
2015-03-02 08:50:13 -05:00
|
|
|
In addition to the HTTP API, the [DNS interface](/docs/agent/dns.html) can
|
|
|
|
be used to query the node. Note that you have to make sure to point your DNS
|
|
|
|
lookups to the Consul agent's DNS server which runs on port 8600 by default.
|
|
|
|
The format of the DNS entries (such as "Armons-MacBook-Air.node.consul") will
|
|
|
|
be covered in more detail later.
|
2014-04-10 17:41:49 -07:00
|
|
|
|
2014-10-19 19:40:10 -04:00
|
|
|
```text
|
2014-04-10 17:41:49 -07:00
|
|
|
$ dig @127.0.0.1 -p 8600 Armons-MacBook-Air.node.consul
|
2014-04-14 12:22:03 -07:00
|
|
|
...
|
2014-04-10 17:41:49 -07:00
|
|
|
|
|
|
|
;; QUESTION SECTION:
|
|
|
|
;Armons-MacBook-Air.node.consul. IN A
|
|
|
|
|
|
|
|
;; ANSWER SECTION:
|
2015-12-27 09:45:59 -06:00
|
|
|
Armons-MacBook-Air.node.consul. 0 IN A 172.20.20.11
|
2014-04-10 17:41:49 -07:00
|
|
|
```
|
|
|
|
|
2015-03-14 14:13:41 -04:00
|
|
|
## <a name="stopping"></a>Stopping the Agent
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
You can use `Ctrl-C` (the interrupt signal) to gracefully halt the agent.
|
2015-02-19 17:12:56 -05:00
|
|
|
After interrupting the agent, you should see it leave the cluster
|
2014-02-07 16:41:03 -08:00
|
|
|
and shut down.
|
|
|
|
|
2014-04-10 17:41:49 -07:00
|
|
|
By gracefully leaving, Consul notifies other cluster members that the
|
2014-02-07 16:41:03 -08:00
|
|
|
node _left_. If you had forcibly killed the agent process, other members
|
2014-04-10 17:41:49 -07:00
|
|
|
of the cluster would have detected that the node _failed_. When a member leaves,
|
2014-05-03 18:23:16 -04:00
|
|
|
its services and checks are removed from the catalog. When a member fails,
|
2014-11-26 11:37:28 +00:00
|
|
|
its health is simply marked as critical, but it is not removed from the catalog.
|
2015-02-19 17:12:56 -05:00
|
|
|
Consul will automatically try to reconnect to _failed_ nodes, allowing it
|
2014-04-10 17:41:49 -07:00
|
|
|
to recover from certain network conditions, while _left_ nodes are no longer contacted.
|
|
|
|
|
|
|
|
Additionally, if an agent is operating as a server, a graceful leave is important
|
2015-03-02 08:50:13 -05:00
|
|
|
to avoid causing a potential availability outage affecting the
|
|
|
|
[consensus protocol](/docs/internals/consensus.html). See the
|
|
|
|
[guides section](/docs/guides/index.html) for details on how to safely add
|
2014-11-26 11:37:28 +00:00
|
|
|
and remove servers.
|
2015-03-02 08:50:13 -05:00
|
|
|
|
|
|
|
## Next Steps
|
|
|
|
|
2015-03-14 14:13:41 -04:00
|
|
|
Your simple Consul cluster is up and running. Let's give it some
|
2015-03-02 08:50:13 -05:00
|
|
|
[services](services.html)!
|