mirror of https://github.com/hashicorp/consul
website: connect native overview
parent
caae034f3b
commit
f522249e6b
Binary file not shown.
After Width: | Height: | Size: 45 KiB |
|
@ -8,4 +8,121 @@ description: |-
|
||||||
|
|
||||||
# Connect-Native App Integration
|
# Connect-Native App Integration
|
||||||
|
|
||||||
TODO
|
Applications can natively integrate with the Connect API to support
|
||||||
|
accepting and establishing connections to other Connect services without
|
||||||
|
the overhead of a [proxy sidecar](/docs/connect/proxies.html). This page
|
||||||
|
will cover the high-level overview of integration, registering the service,
|
||||||
|
etc. For language-specific examples, see the sidebar navigation to the left.
|
||||||
|
|
||||||
|
Connect is just basic mutual TLS. This means that almost any application
|
||||||
|
can easily integrate with Connect. There is no custom protocol in use;
|
||||||
|
any language that supports TLS can accept and establish Connect-based
|
||||||
|
connections.
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
|
The primary work involved in natively integrating with Connect is
|
||||||
|
[acquiring the proper TLS certificate](/api/agent/connect.html#service-leaf-certificate),
|
||||||
|
[verifying TLS certificates](/api/agent/connect.html#certificate-authority-ca-roots),
|
||||||
|
and [authorizing inbound connections](/api/agent/connect.html#authorize).
|
||||||
|
All of this is done using Consul's HTTP API using the previously-linked APIs.
|
||||||
|
|
||||||
|
An overview of the sequence is shown below. The diagram and the following
|
||||||
|
details may seem complex, but this is a _regular mutual TLS connection_ with
|
||||||
|
an API call to verify the incoming client certificate.
|
||||||
|
|
||||||
|
<div class="center">
|
||||||
|
![Native Integration Overview](connect-native-overview.png)
|
||||||
|
</div>
|
||||||
|
|
||||||
|
Details on the steps are below:
|
||||||
|
|
||||||
|
* **Service discovery** - This is normal service discovery using Consul,
|
||||||
|
a static IP, or any other mechanism. If you're using Consul DNS, the
|
||||||
|
[`<service>.connect`](/docs/agent/dns.html#connect-capable-service-lookups)
|
||||||
|
syntax to find Connect-capable endpoints for a service. After service
|
||||||
|
discovery, choose one address from the list of **service addresses**.
|
||||||
|
|
||||||
|
* **Mutual TLS** - As a client, connect to the discovered service address
|
||||||
|
over normal TLS. As part of the TLS connection, provide the
|
||||||
|
[service certificate](/api/agent/connect.html#service-leaf-certificate)
|
||||||
|
as the client certificate. Verify the remote certificate against the
|
||||||
|
[public CA roots](/api/agent/connect.html#certificate-authority-ca-roots).
|
||||||
|
As a client, if the connection is established then you've established
|
||||||
|
a Connect-based connection and there are no further steps!
|
||||||
|
|
||||||
|
* **Authorization** - As a server accepting connections, verify the client
|
||||||
|
certificate against the
|
||||||
|
[public CA roots](/api/agent/connect.html#certificate-authority-ca-roots).
|
||||||
|
After verifying the certificate, parse some basic fields from it and call
|
||||||
|
the [authorizing API](/api/agent/connect.html#authorize) against the local
|
||||||
|
agent. If this returns successfully, complete the TLS handshake and establish
|
||||||
|
the connection. If authorization fails, close the connection.
|
||||||
|
|
||||||
|
-> **A note on performance:** The only API call in the connection path is
|
||||||
|
the [authorization API](/api/agent/connect.html#authorize). The other API
|
||||||
|
calls to acquire the leaf certificate and CA roots are expected to be done
|
||||||
|
out of band and reused. The authorize API call should be called against the
|
||||||
|
local Consul agent. The agent uses locally cached
|
||||||
|
data to authorize the connection and typically responds in microseconds.
|
||||||
|
Therefore, the impact to the TLS handshake is typically microseconds.
|
||||||
|
|
||||||
|
## Updating Certificates and Certificate Roots
|
||||||
|
|
||||||
|
The leaf certificate and CA roots can be updated at any time and the
|
||||||
|
natively integrated application must react to this relatively quickly
|
||||||
|
so that new connections are not disrupted. This can be done through
|
||||||
|
Consul blocking queries (HTTP long polling) or through periodic polling.
|
||||||
|
|
||||||
|
The API calls for
|
||||||
|
[acquiring a leaf TLS certificate](/api/agent/connect.html#service-leaf-certificate)
|
||||||
|
and [reading CA roots](/api/agent/connect.html#certificate-authority-ca-roots)
|
||||||
|
both support
|
||||||
|
[blocking queries](/api/index.html#blocking-queries). By using blocking
|
||||||
|
queries, an application can efficiently wait for an updated value. For example,
|
||||||
|
the leaf certificate API will block until the certificate is near expiration
|
||||||
|
or the signing certificates have changed and will issue and return a new
|
||||||
|
certificate.
|
||||||
|
|
||||||
|
In some languages, using blocking queries may not be simple. In that case,
|
||||||
|
we still recommend using the blocking query parameters but with a very short
|
||||||
|
`timeout` value set. Doing this is documented with
|
||||||
|
[blocking queries](/api/index.html#blocking-queries). The low timeout will
|
||||||
|
ensure the API responds quickly. We recommend that applications poll the
|
||||||
|
certificate endpoints frequently, such as multiple times per minute.
|
||||||
|
|
||||||
|
The overhead for the blocking queries (long or periodic polling) is minimal.
|
||||||
|
The API calls are to the local agent and the local agent uses locally
|
||||||
|
cached data multiplexed over a single TCP connection to the Consul leader.
|
||||||
|
Even if a single machine has 1,000 Connect-enabled services all blocking
|
||||||
|
on certificate updates, this translates to only one TCP connection to the
|
||||||
|
Consul server.
|
||||||
|
|
||||||
|
Some language libraries such as the
|
||||||
|
[Go library](/docs/connect/native/go.html) automatically handle updating
|
||||||
|
and locally caching the certificates.
|
||||||
|
|
||||||
|
## Service Registration
|
||||||
|
|
||||||
|
Connect-native applications must tell Consul that they support Connect
|
||||||
|
natively. This enables the service to be returned as part of service
|
||||||
|
discovery for Connect-capable services, used by other Connect-native applications
|
||||||
|
and client [proxies](/docs/connect/proxies.html).
|
||||||
|
|
||||||
|
This can be specified directly in the [service definition](/docs/agent/services.html):
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"service": {
|
||||||
|
"name": "redis",
|
||||||
|
"port": 8000,
|
||||||
|
"connect": {
|
||||||
|
"native": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Services that support Connect natively are still returned through the standard
|
||||||
|
service discovery mechanisms in addition to the Connect-only service discovery
|
||||||
|
mechanisms.
|
||||||
|
|
|
@ -270,6 +270,11 @@
|
||||||
</li>
|
</li>
|
||||||
<li<%= sidebar_current("docs-connect-native") %>>
|
<li<%= sidebar_current("docs-connect-native") %>>
|
||||||
<a href="/docs/connect/native.html">Native App Integration</a>
|
<a href="/docs/connect/native.html">Native App Integration</a>
|
||||||
|
<ul class="nav">
|
||||||
|
<li<%= sidebar_current("docs-connect-native-go") %>>
|
||||||
|
<a href="/docs/connect/native/go.html">Go Integration</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
<li<%= sidebar_current("docs-connect-dev") %>>
|
<li<%= sidebar_current("docs-connect-dev") %>>
|
||||||
<a href="/docs/connect/dev.html">Develop and Debug</a>
|
<a href="/docs/connect/dev.html">Develop and Debug</a>
|
||||||
|
|
Loading…
Reference in New Issue