2014-10-13 17:46:41 -07:00
|
|
|
---
|
|
|
|
layout: "docs"
|
|
|
|
page_title: "Frequently Asked Questions"
|
|
|
|
sidebar_current: "docs-faq"
|
|
|
|
---
|
|
|
|
|
|
|
|
# Frequently Asked Questions
|
|
|
|
|
2014-10-13 18:03:39 -07:00
|
|
|
## Q: What is Checkpoint? / Does Consul call home?
|
|
|
|
|
|
|
|
Consul makes use of a HashiCorp service called [Checkpoint](http://checkpoint.hashicorp.com)
|
2014-10-20 06:26:38 +00:00
|
|
|
which is used to check for updates and critical security bulletins.
|
2015-03-05 17:56:41 -05:00
|
|
|
Only anonymous information, which cannot be used to identify the user or host, is
|
|
|
|
sent to Checkpoint . An anonymous ID is sent which helps de-duplicate warning messages.
|
2016-11-01 15:11:20 +02:00
|
|
|
This anonymous ID can be disabled. In fact, using the Checkpoint service is optional
|
2014-10-13 18:03:39 -07:00
|
|
|
and can be disabled.
|
|
|
|
|
|
|
|
See [`disable_anonymous_signature`](/docs/agent/options.html#disable_anonymous_signature)
|
|
|
|
and [`disable_update_check`](/docs/agent/options.html#disable_update_check).
|
|
|
|
|
2015-02-06 16:37:34 -08:00
|
|
|
## Q: How does Atlas integration work?
|
2015-02-06 16:34:07 -08:00
|
|
|
|
|
|
|
Consul makes use of a HashiCorp service called [SCADA](http://scada.hashicorp.com)
|
2015-03-05 17:56:41 -05:00
|
|
|
(Supervisory Control And Data Acquisition). The SCADA system allows clients to maintain
|
|
|
|
long-running connections to Atlas. Atlas can in turn provide auto-join facilities for
|
|
|
|
Consul agents (supervisory control) and an integrated dashboard showing the health of
|
|
|
|
all connected agents (data acquisition).
|
2015-02-06 16:34:07 -08:00
|
|
|
|
2015-03-05 17:56:41 -05:00
|
|
|
Standard ACLs can be applied to the SCADA connection, ensuring that Atlas is given only
|
|
|
|
those privileges that make sense for your deployment.
|
2014-10-13 18:03:39 -07:00
|
|
|
|
2015-03-05 17:56:41 -05:00
|
|
|
Using the SCADA service is optional. SCADA is only enabled by opt-in.
|
|
|
|
|
|
|
|
See the [Atlas integration guide](/docs/guides/atlas.html) for more details.
|
2015-03-09 10:01:50 -07:00
|
|
|
|
2015-03-09 10:10:22 -07:00
|
|
|
## Q: Does Consul rely on UDP Broadcast or Multicast?
|
2015-03-09 10:01:50 -07:00
|
|
|
|
2016-08-08 12:44:27 -04:00
|
|
|
Consul uses the [Serf](https://www.serf.io) gossip protocol which relies on
|
2015-03-09 10:10:22 -07:00
|
|
|
TCP and UDP unicast. Broadcast and Multicast are rarely available in a multi-tenant
|
2015-03-09 10:01:50 -07:00
|
|
|
or cloud network environment. For that reason, Consul and Serf were both
|
|
|
|
designed to avoid any dependence on those capabilities.
|
|
|
|
|
2015-03-09 11:46:59 -07:00
|
|
|
## Q: Is Consul eventually or strongly consistent?
|
|
|
|
|
|
|
|
Consul has two important subsystems, the service catalog and the gossip protocol.
|
|
|
|
The service catalog stores all the nodes, service instances, health check data,
|
2017-04-04 12:33:22 -04:00
|
|
|
ACLs, and KV information. It is strongly consistent, and replicated
|
2015-03-09 11:46:59 -07:00
|
|
|
using the [consensus protocol](/docs/internals/consensus.html).
|
|
|
|
|
|
|
|
The [gossip protocol](/docs/internals/gossip.html) is used to track which
|
|
|
|
nodes are part of the cluster and to detect a node or agent failure. This information
|
|
|
|
is eventually consistent by nature. When the servers detects a change in membership,
|
|
|
|
or receive a health update, they update the service catalog appropriately.
|
|
|
|
|
|
|
|
Because of this split, the answer to the question is subtle. Almost all client APIs
|
|
|
|
interact with the service catalog and are strongly consistent. Updates to the
|
|
|
|
catalog may come via the gossip protocol which is eventually consistent, meaning
|
|
|
|
the current state of the catalog can lag behind until the state is reconciled.
|
|
|
|
|
2015-08-06 17:37:48 -07:00
|
|
|
## Q: Are _failed_ or _left_ nodes ever removed?
|
2015-03-18 12:56:12 -04:00
|
|
|
|
2016-04-21 14:24:41 -07:00
|
|
|
To prevent an accumulation of dead nodes (nodes in either _failed_ or _left_
|
|
|
|
states), Consul will automatically remove dead nodes out of the catalog. This
|
|
|
|
process is called _reaping_. This is currently done on a configurable
|
2016-11-25 13:25:09 -05:00
|
|
|
interval of 72 hours. Reaping is similar to leaving, causing all associated
|
|
|
|
services to be deregistered. Changing the reap interval for aesthetic
|
2016-04-21 14:24:41 -07:00
|
|
|
reasons to trim the number of _failed_ or _left_ nodes is not advised (nodes
|
|
|
|
in the _failed_ or _left_ state do not cause any additional burden on
|
|
|
|
Consul).
|
2015-05-04 14:23:33 -07:00
|
|
|
|
|
|
|
## Q: Does Consul support delta updates for watchers or blocking queries?
|
|
|
|
|
|
|
|
Consul does not currently support sending a delta or a change only response
|
|
|
|
to a watcher or a blocking query. The API simply allows for an edge-trigger
|
|
|
|
return with the full result. A client should keep the results of their last
|
|
|
|
read and compute the delta client side.
|
|
|
|
|
|
|
|
By design, Consul offloads this to clients instead of attempting to support
|
|
|
|
the delta calculation. This avoids expensive state maintenance on the servers
|
|
|
|
as well as race conditions between data updates and watch registrations.
|
2016-07-29 13:42:30 -04:00
|
|
|
|
|
|
|
## Q: What network ports does Consul use?
|
|
|
|
|
2016-07-29 14:43:51 -04:00
|
|
|
The [Ports Used](https://www.consul.io/docs/agent/options.html#ports) section of the Configuration documentation lists all ports that Consul uses.
|
2017-03-30 13:56:03 -04:00
|
|
|
|
|
|
|
## Q: Does Consul require certain user process resource limits?
|
|
|
|
|
|
|
|
There should be only a small number of open file descriptors required for a
|
|
|
|
Consul client agent. The gossip layers perform transient connections with
|
|
|
|
other nodes, each connection to the client agent (such as for a blocking
|
|
|
|
query) will open a connection, and there will typically be connections to one
|
|
|
|
of the Consul servers. A small number of file descriptors are also required
|
|
|
|
for watch handlers, health checks, log files, and so on.
|
|
|
|
|
|
|
|
For a Consul server agent, you should plan on the above requirements and
|
|
|
|
an additional incoming connection from each of the nodes in the cluster. This
|
|
|
|
should not be the common case, but in the worst case if there is a problem
|
|
|
|
with the other servers you would expect the other client agents to all
|
|
|
|
connect to a single server and so preparation for this possibility is helpful.
|
|
|
|
|
|
|
|
The default ulimits are usually sufficient for Consul, but you should closely
|
|
|
|
scrutinize your own environment's specific needs and identify the root cause
|
|
|
|
of any excessive resource utilization before arbitrarily increasing the limits.
|