2018-05-29 21:07:40 +00:00
|
|
|
---
|
2020-04-07 18:55:19 +00:00
|
|
|
layout: docs
|
|
|
|
page_title: Connect - Development and Debugging
|
2020-04-13 18:40:26 +00:00
|
|
|
sidebar_title: Develop and Debug
|
2020-04-07 18:55:19 +00:00
|
|
|
description: >-
|
|
|
|
It is often necessary to connect to a service for development or debugging. If
|
|
|
|
a service only exposes a Connect listener, then we need a way to establish a
|
|
|
|
mutual TLS connection to the service. The `consul connect proxy` command can
|
|
|
|
be used for this task on any machine with access to a Consul agent (local or
|
|
|
|
remote).
|
2018-05-29 21:07:40 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
# Developing and Debugging Connect Services
|
|
|
|
|
|
|
|
It is often necessary to connect to a service for development or debugging.
|
|
|
|
If a service only exposes a Connect listener, then we need a way to establish
|
|
|
|
a mutual TLS connection to the service. The
|
2020-04-09 23:46:54 +00:00
|
|
|
[`consul connect proxy` command](/docs/commands/connect/proxy) can be used
|
2018-05-29 21:07:40 +00:00
|
|
|
for this task on any machine with access to a Consul agent (local or remote).
|
|
|
|
|
|
|
|
Restricting access to services only via Connect ensures that the only way to
|
|
|
|
connect to a service is through valid authorization of the
|
2020-04-09 23:46:54 +00:00
|
|
|
[intentions](/docs/connect/intentions). This can extend to developers
|
2018-05-29 21:07:40 +00:00
|
|
|
and operators, too.
|
|
|
|
|
|
|
|
## Connecting to Connect-only Services
|
|
|
|
|
|
|
|
As an example, let's assume that we have a PostgreSQL database running that
|
|
|
|
we want to connect to via `psql`, but the only non-loopback listener is
|
|
|
|
via Connect. Let's also assume that we have an ACL token to identify as
|
|
|
|
`operator-mitchellh`. We can start a local proxy:
|
|
|
|
|
2020-09-10 17:32:06 +00:00
|
|
|
```shell-session
|
2018-05-29 21:07:40 +00:00
|
|
|
$ consul connect proxy \
|
|
|
|
-service operator-mitchellh \
|
|
|
|
-upstream postgresql:8181
|
|
|
|
```
|
|
|
|
|
|
|
|
This works because the source `-service` does not need to be registered
|
|
|
|
in the local Consul catalog. However, to retrieve a valid identifying
|
|
|
|
certificate, the ACL token must have `service:write` permissions. This
|
2020-09-10 17:32:06 +00:00
|
|
|
can be used as a sort of "debug service" to represent people, too. In
|
2018-05-29 21:07:40 +00:00
|
|
|
the example above, the proxy is identifying as `operator-mitchellh`.
|
|
|
|
|
|
|
|
With the proxy running, we can now use `psql` like normal:
|
|
|
|
|
2020-09-10 17:32:06 +00:00
|
|
|
```shell-session
|
2018-05-29 21:07:40 +00:00
|
|
|
$ psql -h 127.0.0.1 -p 8181 -U mitchellh mydb
|
|
|
|
>
|
|
|
|
```
|
|
|
|
|
|
|
|
This `psql` session is now happening through our local proxy via an
|
|
|
|
authorized mutual TLS connection to the PostgreSQL service in our Consul
|
|
|
|
catalog.
|
|
|
|
|
|
|
|
### Masquerading as a Service
|
|
|
|
|
|
|
|
You can also easily masquerade as any source service by setting the
|
|
|
|
`-service` value to any service. Note that the proper ACL permissions are
|
|
|
|
required to perform this task.
|
|
|
|
|
|
|
|
For example, if you have an ACL token that allows `service:write` for
|
|
|
|
`web` and you want to connect to the `postgresql` service as "web", you
|
|
|
|
can start a proxy like so:
|
|
|
|
|
2020-09-10 17:32:06 +00:00
|
|
|
```shell-session
|
2018-05-29 21:07:40 +00:00
|
|
|
$ consul connect proxy \
|
|
|
|
-service web \
|
|
|
|
-upstream postgresql:8181
|
|
|
|
```
|