2018-05-29 14:07:40 -07:00
---
2020-04-07 14:55:19 -04:00
layout: docs
page_title: Connect - Configuration
2020-04-13 14:40:26 -04:00
sidebar_title: Configuration
2020-04-07 14:55:19 -04:00
description: >-
A Connect-aware proxy enables unmodified applications to use Connect. A
per-service proxy sidecar transparently handles inbound and outbound service
connections, automatically wrapping and verifying TLS connections.
2018-05-29 14:07:40 -07:00
---
# Connect Configuration
There are many configuration options exposed for Connect. The only option
that must be set is the "enabled" option on Consul Servers to enable Connect.
All other configurations are optional and have reasonable defaults.
2019-06-13 22:52:50 -07:00
-> **Tip:** Connect is enabled by default when running Consul in
dev mode with `consul agent -dev`.
## Agent Configuration
2018-05-29 14:07:40 -07:00
The first step to use Connect is to enable Connect for your Consul
cluster. By default, Connect is disabled. Enabling Connect requires changing
the configuration of only your Consul _servers_ (not client agents). To enable
Connect, add the following to a new or existing
2020-04-09 19:46:54 -04:00
[server configuration file](/docs/agent/options). In an existing cluster, this configuration change requires a Consul server restart, which you can perform one server at a time to maintain availability. In HCL:
2018-05-29 14:07:40 -07:00
```hcl
connect {
enabled = true
}
```
This will enable Connect and configure your Consul cluster to use the
built-in certificate authority for creating and managing certificates.
You may also configure Consul to use an external
2020-04-09 19:46:54 -04:00
[certificate management system](/docs/connect/ca), such as
2018-05-29 14:07:40 -07:00
[Vault](https://vaultproject.io).
2019-06-13 22:52:50 -07:00
Services and proxies may always register with Connect settings, but they will
fail to retrieve or verify any TLS certificates. This causes all Connect-based
2018-05-29 14:07:40 -07:00
connection attempts to fail until Connect is enabled on the server agents.
2019-06-13 22:52:50 -07:00
Other optional Connect configurations that you can set in the server
configuration file include:
2020-04-09 19:46:54 -04:00
- [certificate authority settings](/docs/agent/options#connect)
- [token replication](/docs/agent/options#acl_tokens_replication)
- [dev mode](/docs/agent/options#_dev)
- [server host name verification](/docs/agent/options#verify_server_hostname)
2018-06-23 00:25:27 +01:00
2019-06-13 22:52:50 -07:00
If you would like to use Envoy as your Connect proxy you will need to [enable
2020-04-09 19:46:54 -04:00
gRPC](/docs/agent/options#grpc_port).
2019-06-13 22:52:50 -07:00
Additionally if you plan on using the observability features of Connect, it can
be convenient to configure your proxies and services using [configuration
2020-04-09 19:46:54 -04:00
entries](/docs/agent/config_entries) which you can interact with using the
2019-06-13 22:52:50 -07:00
CLI or API, or by creating configuration entry files. You will want to enable
[centralized service
2020-04-09 19:46:54 -04:00
configuration](/docs/agent/options#enable_central_service_config) on
2019-06-13 22:52:50 -07:00
clients, which allows each service's proxy configuration to be managed centrally
via API.
!> **Security note:** Enabling Connect is enough to try the feature but doesn't
2018-06-23 00:38:28 +01:00
automatically ensure complete security. Please read the [Connect production
2020-08-17 18:19:04 +02:00
tutorial](https://learn.hashicorp.com/tutorials/consul/service-mesh-production-checklist) to understand the additional steps
2018-06-23 00:38:28 +01:00
needed for a secure deployment.
2019-06-13 22:52:50 -07:00
## Centralized Proxy and Service Configuration
To account for common Connect use cases where you have many instances of the
same service, and many colocated sidecar proxies, Consul allows you to customize
the settings for all of your proxies or all the instances of a given service at
2020-04-09 19:46:54 -04:00
once using [Configuration Entries](/docs/agent/config_entries).
2019-06-13 22:52:50 -07:00
You can override centralized configurations for individual proxy instances in
their
2020-04-09 19:46:54 -04:00
[sidecar service definitions](/docs/connect/registration/sidecar-service),
2019-06-13 22:52:50 -07:00
and the default protocols for service instances in their [service
2020-04-09 19:46:54 -04:00
registrations](/docs/agent/services).
2019-06-13 22:52:50 -07:00
## Schedulers
Consul Connect is especially useful if you are using an orchestrator like Nomad
or Kubernetes, because these orchestrators can deploy thousands of service instances
which frequently move hosts. Sidecars for each service can be configured through
these schedulers, and in some cases they can automate Consul configuration,
sidecar deployment, and service registration.
### Nomad
Connect can be used with Nomad to provide secure service-to-service
communication between Nomad jobs and task groups. The ability to use the dynamic
port feature of Nomad makes Connect particularly easy to use. Learn about how to
configure Connect on Nomad by reading the
2020-04-09 19:46:54 -04:00
[integration documentation](/docs/connect/platform/nomad)
2019-06-13 22:52:50 -07:00
### Kubernetes
2018-06-23 00:25:27 +01:00
2019-06-13 22:52:50 -07:00
The Consul Helm chart can automate much of Consul Connect's configuration, and
makes it easy to automatically inject Envoy sidecars into new pods when they are
2020-04-09 19:46:54 -04:00
deployed. Learn about the [Helm chart](/docs/platform/k8s/helm) in general,
2019-06-13 22:52:50 -07:00
or if you are already familiar with it, check out it's
2020-08-18 18:22:29 -04:00
[connect specific configurations](/docs/platform/k8s/connect).