122 lines
6.1 KiB
Plaintext
Raw Normal View History

2014-02-07 16:41:03 -08:00
---
layout: docs
page_title: Intro to Consul
2020-04-07 14:55:19 -04:00
description: >-
Welcome to the intro guide to Consul! This guide is the best place to start
with Consul. We cover what Consul is, what problems it can solve, how it
compares to existing software, and how you can get started using it. If you
are familiar with the basics of Consul, the documentation provides a more
detailed reference of available features.
2014-02-07 16:41:03 -08:00
---
2014-04-10 13:31:47 -07:00
# Introduction to Consul
2014-02-07 16:41:03 -08:00
2014-04-19 11:55:59 +02:00
Welcome to the intro guide to Consul! This guide is the best place to start
2014-04-10 13:31:47 -07:00
with Consul. We cover what Consul is, what problems it can solve, how it compares
2015-02-18 16:45:10 -05:00
to existing software, and how you can get started using it. If you are familiar
2020-04-09 19:20:00 -04:00
with the basics of Consul, the [documentation](/docs) provides a more
2021-02-22 08:32:07 -08:00
detailed reference of available features. If you're ready to get hands-on
2021-12-21 14:34:56 -07:00
experience, deploy Consul locally with our
2021-02-22 08:32:07 -08:00
[HashiCorp Learn tutorial](https://learn.hashicorp.com/tutorials/consul/get-started-install).
2014-02-07 16:41:03 -08:00
2021-12-21 15:05:12 -07:00
## Why Consul?
Consul solves the challenges that organizations of all sizes encounter with microservices architectures. This ranges from operating in various distributed environments and geographical locations, to meeting the need of securing all application traffic.
The world is rapidly changing and evolving, so is the computing networking layer.
Today's network must quickly adapt and ensure communication is encrypted at all times. Consul enables organizations to embrace a [zero trust](https://www.hashicorp.com/solutions/zero-trust-security) model while scaling up.
Consul can achieve all this while reducing the burden on both operators and developers through automation of crucial networking tasks
![Diagram that explains why Consul](/img/intro_why_consul_diagram.svg)
2014-04-10 13:31:47 -07:00
## What is Consul?
2014-02-07 16:41:03 -08:00
Consul is a service mesh solution providing a full featured control plane
with service discovery, configuration, and segmentation functionality. Each
of these features can be used individually as needed, or they can be used
together to build a full service mesh. Consul requires a data plane and
supports both a proxy and native integration model. Consul ships with a
simple built-in proxy so that everything works out of the box, but also
supports 3rd party proxy integrations such as Envoy.
2020-04-06 16:27:35 -04:00
Review the video below to learn more about Consul from HashiCorp's co-founder Armon.
2020-04-07 14:55:19 -04:00
<iframe
src="https://www.youtube.com/embed/mxeMdl0KvBI"
frameborder="0"
allowfullscreen="true"
width="560"
height="315"
></iframe>
The key features of Consul are:
2014-02-07 16:41:03 -08:00
2020-04-06 16:27:35 -04:00
- **Service Discovery**: Clients of Consul can register a service, such as
`api` or `mysql`, and other clients can use Consul to discover providers
2014-04-10 13:31:47 -07:00
of a given service. Using either DNS or HTTP, applications can easily find
the services they depend upon.
2014-02-07 16:41:03 -08:00
2020-04-06 16:27:35 -04:00
- **Health Checking**: Consul clients can provide any number of health checks,
2014-04-10 13:31:47 -07:00
either associated with a given service ("is the webserver returning 200 OK"), or
with the local node ("is memory utilization below 90%"). This information can be
used by an operator to monitor cluster health, and it is used by the service
discovery components to route traffic away from unhealthy hosts.
2014-02-07 16:41:03 -08:00
2020-04-06 16:27:35 -04:00
- **KV Store**: Applications can make use of Consul's hierarchical key/value
2015-02-18 16:45:10 -05:00
store for any number of purposes, including dynamic configuration, feature flagging,
coordination, leader election, and more. The simple HTTP API makes it easy to use.
2014-02-07 16:41:03 -08:00
2020-04-06 16:27:35 -04:00
- **Secure Service Communication**: Consul can generate and distribute TLS
certificates for services to establish mutual TLS connections.
2020-04-09 19:46:54 -04:00
[Intentions](/docs/connect/intentions)
2018-06-19 20:31:27 +09:00
can be used to define which services are allowed to communicate.
2018-06-20 15:03:02 +09:00
Service segmentation can be easily managed with intentions that can
be changed in real time instead of using complex network topologies
and static firewall rules.
2020-04-06 16:27:35 -04:00
- **Multi Datacenter**: Consul supports multiple datacenters out of the box. This
2014-04-10 13:31:47 -07:00
means users of Consul do not have to worry about building additional layers of
abstraction to grow to multiple regions.
2014-02-07 16:41:03 -08:00
2014-04-14 14:08:42 -07:00
Consul is designed to be friendly to both the DevOps community and
application developers, making it perfect for modern, elastic infrastructures.
2014-04-14 12:09:32 -07:00
## Basic Architecture of Consul
2015-02-18 16:45:10 -05:00
Consul is a distributed, highly available system. This section will cover the
basics, purposely omitting some unnecessary detail, so you can get a quick
understanding of how Consul works. For more detail, please refer to the
[in-depth architecture overview](/docs/architecture).
2014-04-14 12:09:32 -07:00
Every node that provides services to Consul runs a _Consul agent_. Running
an agent is not required for discovering other services or getting/setting
key/value data. The agent is responsible for health checking the services
on the node as well as the node itself.
The agents talk to one or more _Consul servers_. The Consul servers are
where data is stored and replicated. The servers themselves elect a leader.
While Consul can function with one server, 3 to 5 is recommended to avoid
2015-02-18 16:45:10 -05:00
failure scenarios leading to data loss. A cluster of Consul servers is recommended
for each datacenter.
2014-04-14 12:09:32 -07:00
The servers maintain a _catalog_, which is formed by aggregating information
submitted by the agents. The catalog maintains the high-level view of the cluster,
2020-04-06 16:27:35 -04:00
including which services are available, which nodes run those services, health
information, and more. How agents and the catalog interact can be found
[here](/docs/architecture/anti-entropy#catalog).
2014-04-14 12:09:32 -07:00
Components of your infrastructure that need to discover other services
or nodes can query any of the Consul servers _or_ any of the Consul agents.
The agents forward queries to the servers automatically.
Each datacenter runs a cluster of Consul servers. When a cross-datacenter
service discovery or configuration request is made, the local Consul servers
forward the request to the remote datacenter and return the result.
## Next Steps
- See [how Consul compares to other software](/docs/intro/vs) to assess how it fits into your
2020-04-06 16:27:35 -04:00
existing infrastructure.
2021-02-22 08:32:07 -08:00
- Continue onwards with [HashiCorp Learn](https://learn.hashicorp.com/tutorials/consul/get-started-install)
2021-12-21 14:34:56 -07:00
to learn more about Consul and how to get Consul up and running.