2014-02-19 11:05:42 -08:00
---
2020-04-07 14:55:19 -04:00
layout: docs
2022-09-15 12:10:20 -05:00
page_title: Find services with DNS
2020-04-07 14:55:19 -04:00
description: >-
2022-09-16 10:28:32 -05:00
For service discovery use cases, Domain Name Service (DNS) is the main interface to look up, query, and address Consul nodes and services. Learn how a Consul DNS lookup can help you find services by tag, name, namespace, partition, datacenter, or domain.
2014-02-19 11:05:42 -08:00
---
2022-09-13 14:38:47 -05:00
# Query services with DNS
2014-02-19 11:05:42 -08:00
2014-11-26 13:32:19 +00:00
One of the primary query interfaces for Consul is DNS.
2014-02-19 11:05:42 -08:00
The DNS interface allows applications to make use of service
2015-01-31 13:01:00 -05:00
discovery without any high-touch integration with Consul.
2014-02-19 11:05:42 -08:00
2015-01-31 13:01:00 -05:00
For example, instead of making HTTP API requests to Consul,
a host can use the DNS server directly via name lookups
2016-11-25 11:00:02 -05:00
like `redis.service.us-east-1.consul`. This query automatically
translates to a lookup of nodes that provide the `redis` service,
are located in the `us-east-1` datacenter, and have no failing health checks.
2015-01-31 13:01:00 -05:00
It's that simple!
2014-02-19 11:05:42 -08:00
2015-01-31 13:07:21 -05:00
There are a number of configuration options that are important for the DNS interface,
2022-01-10 17:30:50 -08:00
specifically [`client_addr`](/docs/agent/config/config-files#client_addr),[`ports.dns`](/docs/agent/config/config-files#dns_port),
[`recursors`](/docs/agent/config/config-files#recursors),[`domain`](/docs/agent/config/config-files#domain),
[`alt_domain`](/docs/agent/config/config-files#alt_domain), and [`dns_config`](/docs/agent/config/config-files#dns_config).
2016-11-25 11:00:02 -05:00
By default, Consul will listen on 127.0.0.1:8600 for DNS queries in the `consul.`
2015-03-23 15:48:35 -04:00
domain, without support for further DNS recursion. Please consult the
2022-01-10 13:13:13 -08:00
[documentation on configuration options](/docs/agent/config),
2015-03-23 15:48:35 -04:00
specifically the configuration items linked above, for more details.
2014-02-19 11:05:42 -08:00
There are a few ways to use the DNS interface. One option is to use a custom
DNS resolver library and point it at Consul. Another option is to set Consul
2015-03-23 15:48:35 -04:00
as the DNS server for a node and provide a
2022-01-10 17:30:50 -08:00
[`recursors`](/docs/agent/config/config-files#recursors) configuration so that non-Consul queries
2014-02-19 11:05:42 -08:00
can also be resolved. The last method is to forward all queries for the "consul."
2020-04-06 16:27:35 -04:00
domain to a Consul agent from the existing DNS server. Review the
2022-09-06 08:35:01 -07:00
[DNS Forwarding tutorial](https://learn.hashicorp.com/tutorials/consul/dns-forwarding?utm_source=docs) for examples.
2015-01-31 12:51:28 -05:00
You can experiment with Consul's DNS server on the command line using tools such as `dig`:
2014-02-19 11:05:42 -08:00
2020-05-19 14:32:38 -04:00
```shell-session
2020-04-07 19:56:08 -04:00
$ dig @127.0.0.1 -p 8600 redis.service.dc1.consul. ANY
```
2014-02-19 11:05:42 -08:00
2016-11-25 11:00:02 -05:00
-> **Note:** In DNS, all queries are case-insensitive. A lookup of `PostgreSQL.node.dc1.consul` will find all nodes named `postgresql`.
2015-01-31 13:07:21 -05:00
2014-02-19 11:05:42 -08:00
## Node Lookups
2015-01-31 12:51:28 -05:00
To resolve names, Consul relies on a very specific format for queries.
There are fundamentally two types of queries: node lookups and service lookups.
A node lookup, a simple query for the address of a named node, looks like this:
2014-02-19 11:05:42 -08:00
2020-04-07 14:55:19 -04:00
```text
2022-08-02 06:30:06 -07:00
<node>.node[.<datacenter>].<domain>
2020-04-07 14:55:19 -04:00
```
2014-02-19 11:05:42 -08:00
2016-11-25 11:00:02 -05:00
For example, if we have a `foo` node with default settings, we could
look for `foo.node.dc1.consul.` The datacenter is an optional part of
the FQDN: if not provided, it defaults to the datacenter of the agent.
If we know `foo` is running in the same datacenter as our local agent,
we can instead use `foo.node.consul.` This convention allows for terse
syntax where appropriate while supporting queries of nodes in remote
datacenters as necessary.
2014-02-19 11:05:42 -08:00
2018-05-29 14:07:40 -07:00
For a node lookup, the only records returned are A and AAAA records
containing the IP address, and TXT records containing the
2017-08-05 01:08:06 -04:00
`node_meta` values of the node.
2014-02-19 11:05:42 -08:00
2020-05-19 14:32:38 -04:00
```shell-session
2015-01-31 12:51:28 -05:00
$ dig @127.0.0.1 -p 8600 foo.node.consul ANY
2014-02-19 11:05:42 -08:00
2015-01-31 12:51:28 -05:00
; <<>> DiG 9.8.3-P1 <<>> @127.0.0.1 -p 8600 foo.node.consul ANY
2014-10-19 19:40:10 -04:00
; (1 server found)
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 24355
;; flags: qr aa rd; QUERY: 1, ANSWER: 1, AUTHORITY: 1, ADDITIONAL: 0
;; WARNING: recursion requested but not available
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
;; QUESTION SECTION:
2022-08-02 06:30:06 -07:00
;foo.node.consul. IN ANY
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
;; ANSWER SECTION:
2022-08-02 06:30:06 -07:00
foo.node.consul. 0 IN A 10.1.10.12
foo.node.consul. 0 IN TXT "meta_key=meta_value"
foo.node.consul. 0 IN TXT "value only"
2017-08-05 01:08:06 -04:00
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
;; AUTHORITY SECTION:
2022-08-02 06:30:06 -07:00
consul. 0 IN SOA ns.consul. postmaster.consul. 1392836399 3600 600 86400 0
2014-10-19 19:40:10 -04:00
```
2014-02-19 11:05:42 -08:00
2018-05-29 14:07:40 -07:00
By default the TXT records value will match the node's metadata key-value
pairs according to [RFC1464](https://www.ietf.org/rfc/rfc1464.txt).
Alternatively, the TXT record will only include the node's metadata value when the
2017-08-05 01:08:06 -04:00
node's metadata key starts with `rfc1035-`.
2022-08-30 15:17:35 -07:00
### Node Lookups for Consul Enterprise <EnterpriseAlert inline />
Consul nodes exist at the admin partition level within a datacenter.
By default, the partition and datacenter used in a [node lookup](#node-lookups) are
the partition and datacenter of the Consul agent that received the DNS query.
Use the following query format to specify a partition for a node lookup:
```text
2022-08-31 13:58:23 -04:00
<node>.node.<partition>.ap.<datacenter>.dc.<domain>
2022-08-30 15:17:35 -07:00
```
Consul server agents are in the `default` partition.
If DNS queries are addressed to Consul server agents,
node lookups to non-`default` partitions must explicitly specify
the partition of the target node.
2014-02-19 11:05:42 -08:00
## Service Lookups
2016-11-25 13:25:09 -05:00
A service lookup is used to query for service providers. Service queries support
2015-01-31 12:51:28 -05:00
two lookup methods: standard and strict [RFC 2782](https://tools.ietf.org/html/rfc2782).
2014-02-19 11:05:42 -08:00
2018-09-07 16:30:47 +02:00
By default, SRV weights are all set at 1, but changing weights is supported using the
2022-01-10 15:36:16 -08:00
`Weights` attribute of the [service definition](/docs/discovery/services).
2018-09-07 16:30:47 +02:00
Note that DNS is limited in size per request, even when performing DNS TCP
queries.
2020-04-06 16:27:35 -04:00
For services having many instances (more than 500), it might not be possible to
2018-09-07 16:30:47 +02:00
retrieve the complete list of instances for the service.
When DNS SRV response are sent, order is randomized, but weights are not
2020-04-06 16:27:35 -04:00
taken into account. In the case of truncation different clients using weighted SRV
responses will have partial and inconsistent views of instances weights so the
request distribution could be skewed from the intended weights. In that case,
2018-09-07 16:30:47 +02:00
it is recommended to use the HTTP API to retrieve the list of nodes.
2014-11-26 13:32:19 +00:00
### Standard Lookup
2014-08-18 15:45:56 -04:00
2014-11-26 13:32:19 +00:00
The format of a standard service lookup is:
2014-08-18 15:45:56 -04:00
2020-04-07 14:55:19 -04:00
```text
2022-08-02 06:30:06 -07:00
[<tag>.]<service>.service[.<datacenter>].<domain>
2020-04-07 14:55:19 -04:00
```
2014-02-19 11:05:42 -08:00
2016-11-25 11:00:02 -05:00
The `tag` is optional, and, as with node lookups, the `datacenter` is as
well. If no tag is provided, no filtering is done on tag. If no
datacenter is provided, the datacenter of this Consul agent is assumed.
2015-01-31 12:51:28 -05:00
2016-11-25 11:00:02 -05:00
If we want to find any redis service providers in our local datacenter,
2016-11-29 15:01:38 -08:00
we could query `redis.service.consul.` If we want to find the PostgreSQL
2016-11-25 11:00:02 -05:00
primary in a particular datacenter, we could query
`primary.postgresql.service.dc2.consul.`
2014-02-19 11:05:42 -08:00
The DNS query system makes use of health check information to prevent routing
to unhealthy nodes. When a service query is made, any services failing their health
2015-01-31 12:51:28 -05:00
check or failing a node system check will be omitted from the results. To allow
2014-02-19 11:05:42 -08:00
for simple load balancing, the set of nodes returned is also randomized each time.
2015-01-31 13:17:43 -05:00
These mechanisms make it easy to use DNS along with application-level retries
2015-01-31 12:51:28 -05:00
as the foundation for an auto-healing service oriented architecture.
2014-02-19 11:05:42 -08:00
2015-01-31 12:51:28 -05:00
For standard services queries, both A and SRV records are supported. SRV records
provide the port that a service is registered on, enabling clients to avoid relying
2014-04-08 12:18:05 -07:00
on well-known ports. SRV records are only served if the client specifically requests
2015-01-31 12:51:28 -05:00
them, like so:
2014-02-19 11:05:42 -08:00
2020-05-19 14:32:38 -04:00
```shell-session
2014-10-19 19:40:10 -04:00
$ dig @127.0.0.1 -p 8600 consul.service.consul SRV
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
; <<>> DiG 9.8.3-P1 <<>> @127.0.0.1 -p 8600 consul.service.consul ANY
; (1 server found)
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 50483
;; flags: qr aa rd; QUERY: 1, ANSWER: 3, AUTHORITY: 1, ADDITIONAL: 1
;; WARNING: recursion requested but not available
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
;; QUESTION SECTION:
2022-08-02 06:30:06 -07:00
;consul.service.consul. IN SRV
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
;; ANSWER SECTION:
2022-08-02 06:30:06 -07:00
consul.service.consul. 0 IN SRV 1 1 8300 foobar.node.dc1.consul.
2014-02-19 11:05:42 -08:00
2014-10-19 19:40:10 -04:00
;; ADDITIONAL SECTION:
2022-08-02 06:30:06 -07:00
foobar.node.dc1.consul. 0 IN A 10.1.10.12
2014-10-19 19:40:10 -04:00
```
2014-02-19 11:05:42 -08:00
2014-11-26 13:32:19 +00:00
### RFC 2782 Lookup
2014-08-18 15:45:56 -04:00
2022-08-02 06:30:06 -07:00
Valid formats for RFC 2782 SRV lookups depend on
whether you want to filter results based on a service tag:
2014-08-18 15:45:56 -04:00
2022-09-20 14:43:17 -07:00
- No filtering on service tag:
2014-08-18 15:45:56 -04:00
2022-08-02 06:30:06 -07:00
```text
_<service>._tcp[.service][.<datacenter>].<domain>
```
2022-09-20 14:43:17 -07:00
- Filtering on service tag specified in the RFC 2782 protocol field:
2022-08-02 06:30:06 -07:00
```text
_<service>._<tag>[.service][.<datacenter>].<domain>
```
Per [RFC 2782](https://tools.ietf.org/html/rfc2782), SRV queries must
prepend an underscore (`_`) to the `service` and `protocol` values in a query to
prevent DNS collisions.
To perform no tag-based filtering, specify `tcp` in the RFC 2782 protocol field.
To filter results on a service tag, specify the tag in the RFC 2782 protocol field.
2014-08-18 15:45:56 -04:00
2016-11-25 11:00:02 -05:00
Other than the query format and default `tcp` protocol/tag value, the behavior
2014-08-18 15:45:56 -04:00
of the RFC style lookup is the same as the standard style of lookup.
2016-11-25 11:00:02 -05:00
If you registered the service `rabbitmq` on port 5672 and tagged it with `amqp`,
you could make an RFC 2782 query for its SRV record as `_rabbitmq._amqp.service.consul`:
2014-08-18 15:45:56 -04:00
2020-05-19 14:32:38 -04:00
```shell-session
2014-10-19 19:40:10 -04:00
$ dig @127.0.0.1 -p 8600 _rabbitmq._amqp.service.consul SRV
2014-08-18 15:45:56 -04:00
2014-10-19 19:40:10 -04:00
; <<>> DiG 9.8.3-P1 <<>> @127.0.0.1 -p 8600 _rabbitmq._amqp.service.consul ANY
; (1 server found)
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 52838
;; flags: qr aa rd; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1
;; WARNING: recursion requested but not available
2014-08-18 15:45:56 -04:00
2014-10-19 19:40:10 -04:00
;; QUESTION SECTION:
2022-08-02 06:30:06 -07:00
;_rabbitmq._amqp.service.consul. IN SRV
2014-08-18 15:45:56 -04:00
2014-10-19 19:40:10 -04:00
;; ANSWER SECTION:
2022-08-02 06:30:06 -07:00
_rabbitmq._amqp.service.consul. 0 IN SRV 1 1 5672 rabbitmq.node1.dc1.consul.
2014-08-18 15:45:56 -04:00
2014-10-19 19:40:10 -04:00
;; ADDITIONAL SECTION:
2022-08-02 06:30:06 -07:00
rabbitmq.node1.dc1.consul. 0 IN A 10.1.11.20
2014-10-19 19:40:10 -04:00
```
2014-08-18 15:45:56 -04:00
2015-01-31 12:59:03 -05:00
Again, note that the SRV record returns the port of the service as well as its IP.
2022-01-19 09:45:30 -08:00
#### SRV response for hosts in the .addr subdomain
If a service registered to Consul has an explicit IP [`address`](/api-docs/agent/service#address)
or tagged address(es) defined on the service registration, the hostname returned
in the target field of the answer section for the DNS SRV query for the service
will be in the format of `<hexadecimal-encoded IP>.addr.<datacenter>.consul`.
<Tabs>
<Tab heading="IPv4">
In the example below, the `rabbitmq` service has been registered with an explicit
IPv4 address of `192.0.2.10`.
<CodeTabs heading="Service defined with explicit IPv4 address in agent config" filename="agent-config.hcl">
```hcl
node_name = "node1"
services {
name = "rabbitmq"
address = "192.0.2.10"
port = 5672
}
```
```json
{
"node_name": "node1",
"services": [
{
"name": "rabbitmq",
"address": "192.0.2.10",
"port": 5672
}
]
}
```
</CodeTabs>
When performing an SRV query for this service, the SRV response contains a single
record with a hostname in the format of `<hexadecimal-encoded IP>.addr.<datacenter>.consul`.
```shell-session
$ dig @127.0.0.1 -p 8600 -t srv _rabbitmq._tcp.service.consul +short
1 1 5672 c000020a.addr.dc1.consul.
```
In this example, the hex-encoded IP from the returned hostname is `c000020a`.
Converting each hex octet to decimal reveals the IP address that was specified
in the service registration.
```shell-session
$ echo -n "c000020a" | perl -ne 'printf("%vd\n", pack("H*", $_))'
192.0.2.10
```
</Tab>
<Tab heading="IPv6">
In the example below, the `rabbitmq` service has been registered with an explicit
IPv6 address of `2001:db8:1:2:cafe::1337`.
<CodeTabs heading="Service defined with explicit IPv6 address in agent config" filename="agent-config.hcl">
```hcl
node_name = "node1"
services {
name = "rabbitmq"
address = "2001:db8:1:2:cafe::1337"
port = 5672
}
```
```json
{
"node_name": "node1",
"services": [
{
"name": "rabbitmq",
"address": "2001:db8:1:2:cafe::1337",
"port": 5672
}
]
}
```
</CodeTabs>
2022-05-10 07:28:33 -07:00
When performing an SRV query for this service, the SRV response contains a single
2022-01-19 09:45:30 -08:00
record with a hostname in the format of `<hexadecimal-encoded IP>.addr.<datacenter>.consul`.
```shell-session
$ dig @127.0.0.1 -p 8600 -t srv _rabbitmq._tcp.service.consul +short
1 1 5672 20010db800010002cafe000000001337.addr.dc1.consul.
```
In this example, the hex-encoded IP from the returned hostname is
`20010db800010002cafe000000001337`. This is the fully expanded IPv6 address with
colon separators removed.
The following command re-adds the colon separators to display the fully expanded
IPv6 address that was specified in the service registration.
```shell-session
$ echo -n "20010db800010002cafe000000001337" | perl -ne 'printf join(":", unpack("(A4)*", $_))."\n"'
2001:0db8:0001:0002:cafe:0000:0000:1337
```
</Tab>
</Tabs>
2022-08-30 15:17:35 -07:00
### Service Lookups for Consul Enterprise <EnterpriseAlert inline />
By default, all service lookups use the `default` namespace
within the partition and datacenter of the Consul agent that received the DNS query.
2022-09-19 14:31:15 -07:00
To lookup services in another namespace, partition, and/or datacenter,
use the [canonical format](#canonical-format).
2022-08-30 15:17:35 -07:00
Consul server agents are in the `default` partition.
If DNS queries are addressed to Consul server agents,
service lookups to non-`default` partitions must explicitly specify
the partition of the target service.
To lookup services imported from a cluster peer,
2022-09-19 14:31:15 -07:00
refer to [service virtual IP lookups for Consul Enterprise](#service-virtual-ip-lookups-for-consul-enterprise) instead.
#### Canonical format
Use the following query format to specify namespace, partition, and/or datacenter
2022-09-20 14:43:17 -07:00
for `.service`, `.connect`, `.virtual`, and `.ingress` service lookup types.
2022-09-19 14:31:15 -07:00
All three fields (`namespace`, `partition`, `datacenter`) are optional.
```text
[<tag>.]<service>.service[.<namespace>.ns][.<partition>.ap][.<datacenter>.dc]<domain>
```
#### Alternative formats for specifying namespace
Though the [canonical format](#canonical-format) is recommended for readability,
2022-09-20 14:43:17 -07:00
you can use the following query formats specify namespace but not partition:
2022-09-19 14:31:15 -07:00
2022-09-20 14:43:17 -07:00
- Specify both namespace and datacenter:
2022-09-19 14:31:15 -07:00
```text
[<tag>.]<service>.service.<namespace>.<datacenter>.<domain>
```
- **Deprecated in Consul 1.11:**
2022-09-20 14:43:17 -07:00
Specify namespace without a datacenter,
which requires that DNS queries are addressed to a Consul agent with
2022-09-19 14:31:15 -07:00
[`dns_config.prefer_namespace`](/docs/agent/config/config-files#dns_prefer_namespace)
2022-09-20 14:43:17 -07:00
set to `true`:
2022-09-19 14:31:15 -07:00
```text
[<tag>.]<service>.service.<namespace>.<domain>
```
2022-08-30 15:17:35 -07:00
2015-11-14 12:45:34 -08:00
### Prepared Query Lookups
2022-11-20 17:21:24 -05:00
The following formats are valid for prepared query lookups:
2015-11-14 12:45:34 -08:00
2022-11-20 17:21:24 -05:00
- Standard lookup
```text
<query name or id>.query[.<datacenter>].<domain>
```
- [RFC 2782](https://tools.ietf.org/html/rfc2782) SRV lookup
```text
_<query name or id>._tcp.query[.<datacenter>].<domain>
```
2015-11-14 12:45:34 -08:00
The `datacenter` is optional, and if not provided, the datacenter of this Consul
agent is assumed.
2022-11-20 17:21:24 -05:00
The `query name or id` is the given name or ID of an existing
2022-03-30 16:16:26 -05:00
[Prepared Query](/api-docs/query). These behave like standard service
2015-11-14 12:45:34 -08:00
queries but provide a much richer set of features, such as filtering by multiple
tags and automatically failing over to look for services in remote datacenters if
2016-03-02 21:56:03 -08:00
no healthy nodes are available in the local datacenter. Consul 0.6.4 and later also
2022-03-30 16:16:26 -05:00
added support for [prepared query templates](/api-docs/query#prepared-query-templates)
2016-03-02 21:56:03 -08:00
which can match names using a prefix match, allowing one template to apply to
potentially many services.
2015-11-14 12:45:34 -08:00
To allow for simple load balancing, the set of nodes returned is randomized each time.
Both A and SRV records are supported. SRV records provide the port that a service is
registered on, enabling clients to avoid relying on well-known ports. SRV records are
only served if the client specifically requests them.
2018-05-29 14:07:40 -07:00
### Connect-Capable Service Lookups
To find Connect-capable services:
2020-04-07 14:55:19 -04:00
```text
<service>.connect.<domain>
```
2018-05-29 14:07:40 -07:00
2020-04-09 19:20:00 -04:00
This will find all [Connect-capable](/docs/connect)
2018-05-29 14:07:40 -07:00
endpoints for the given `service`. A Connect-capable endpoint may be
both a proxy for a service or a natively integrated Connect application.
The DNS interface does not differentiate the two.
2020-04-09 19:46:54 -04:00
Most services will use a [proxy](/docs/connect/proxies) that handles
2018-05-29 14:07:40 -07:00
service discovery automatically and therefore won't use this DNS format.
2020-04-09 19:46:54 -04:00
This DNS format is primarily useful for [Connect-native](/docs/connect/native)
2018-05-29 14:07:40 -07:00
applications.
This endpoint currently only finds services within the same datacenter
and doesn't support tags. This DNS interface will be expanded over time.
If you need more complex behavior, please use the
2022-03-30 16:16:26 -05:00
[catalog API](/api-docs/catalog).
2018-05-29 14:07:40 -07:00
2021-12-14 11:39:17 -08:00
### Service Virtual IP Lookups
To find the unique virtual IP allocated for a service:
```text
2022-08-02 06:30:06 -07:00
<service>.virtual[.<peer>].<domain>
2021-12-14 11:39:17 -08:00
```
This will return the unique virtual IP for any [Connect-capable](/docs/connect)
service. Each Connect service has a virtual IP assigned to it by Consul - this is used
by sidecar proxies for the [Transparent Proxy](/docs/connect/transparent-proxy) feature.
2022-07-06 10:30:04 -06:00
The peer name is an optional part of the FQDN, and it is used to query for the virtual IP
of a service imported from that peer.
2021-12-14 11:39:17 -08:00
The virtual IP is also added to the service's [Tagged Addresses](/docs/discovery/services#tagged-addresses)
under the `consul-virtual` tag.
2022-08-30 15:17:35 -07:00
#### Service Virtual IP Lookups for Consul Enterprise <EnterpriseAlert inline />
By default, a service virtual IP lookup uses the `default` namespace
within the partition and datacenter of the Consul agent that received the DNS query.
To lookup services imported from a cluster peered partition or open-source datacenter,
specify the namespace and peer name in the lookup:
```text
<service>.virtual[.<namespace>].<peer>.<domain>
```
2021-12-14 11:39:17 -08:00
2022-08-30 15:17:35 -07:00
To lookup services not imported from a cluster peer,
refer to [service lookups for Consul Enterprise](#service-lookups-for-consul-enterprise) instead.
2020-05-13 16:29:40 -05:00
### Ingress Service Lookups
To find ingress-enabled services:
```text
<service>.ingress.<domain>
```
2022-01-10 15:36:16 -08:00
This will find all [ingress gateway](/docs/connect/gateways/ingress-gateway)
2020-05-13 16:29:40 -05:00
endpoints for the given `service`.
This endpoint currently only finds services within the same datacenter
and doesn't support tags. This DNS interface will be expanded over time.
If you need more complex behavior, please use the
2022-03-30 16:16:26 -05:00
[catalog API](/api-docs/catalog).
2020-05-13 16:29:40 -05:00
2014-08-18 15:45:56 -04:00
### UDP Based DNS Queries
2014-05-20 16:43:44 -07:00
When the DNS query is performed using UDP, Consul will truncate the results
without setting the truncate bit. This is to prevent a redundant lookup over
2014-11-26 13:32:19 +00:00
TCP that generates additional load. If the lookup is done over TCP, the results
2014-05-20 16:43:44 -07:00
are not truncated.
2014-02-19 11:05:42 -08:00
2021-12-07 15:10:14 -05:00
## Alternative Domain
By default, Consul responds to DNS queries in the `consul` domain,
2022-01-10 17:30:50 -08:00
but you can set a specific domain for responding to DNS queries by configuring the [`domain`](/docs/agent/config/config-files#domain) parameter.
2021-12-07 15:10:14 -05:00
In some instances, Consul may need to respond to queries in more than one domain,
such as during a DNS migration or to distinguish between internal and external queries.
Consul versions 1.5.2+ can be configured to respond to DNS queries on an alternative domain
2022-01-10 17:30:50 -08:00
through the [`alt_domain`](/docs/agent/config/config-files#alt_domain) agent configuration
2021-12-07 15:10:14 -05:00
option. As of Consul versions 1.11.0+, Consul's DNS response will use the same domain as was used in the query;
2022-01-10 17:30:50 -08:00
in prior versions, the response may use the primary [`domain`](/docs/agent/config/config-files#domain) no matter which
2021-12-07 15:10:14 -05:00
domain was used in the query.
In the following example, the `alt_domain` parameter is set to `test-domain`:
```hcl
alt_domain = "test-domain"
```
```shell-session
2022-01-12 15:05:01 -08:00
$ dig @127.0.0.1 -p 8600 consul.service.test-domain SRV
2021-12-07 15:10:14 -05:00
```
2022-01-12 15:05:01 -08:00
2021-12-07 15:10:14 -05:00
The following responses are returned:
```
;; QUESTION SECTION:
2022-08-02 06:30:06 -07:00
;consul.service.test-domain. IN SRV
2021-12-07 15:10:14 -05:00
;; ANSWER SECTION:
2022-08-02 06:30:06 -07:00
consul.service.test-domain. 0 IN SRV 1 1 8300 machine.node.dc1.test-domain.
2021-12-07 15:10:14 -05:00
;; ADDITIONAL SECTION:
2022-08-02 06:30:06 -07:00
machine.node.dc1.test-domain. 0 IN A 127.0.0.1
machine.node.dc1.test-domain. 0 IN TXT "consul-network-segment="
2021-12-07 15:10:14 -05:00
```
2022-03-15 16:13:58 -07:00
-> **PTR queries:** Responses to PTR queries (`<ip>.in-addr.arpa.`) will always use the
2022-01-10 17:30:50 -08:00
[primary domain](/docs/agent/config/config-files#domain) (not the alternative domain),
2022-03-15 16:13:58 -07:00
as there is no way for the query to specify a domain.
2021-12-07 15:10:14 -05:00
2014-06-08 17:26:41 -07:00
## Caching
By default, all DNS results served by Consul set a 0 TTL value. This disables
caching of DNS results. However, there are many situations in which caching is
2020-08-17 18:17:51 +02:00
desirable for performance and scalability. This is discussed more in the tutorial
2022-09-06 08:35:01 -07:00
for [DNS caching](https://learn.hashicorp.com/tutorials/consul/dns-caching).
2016-02-07 10:56:47 -08:00
## WAN Address Translation
2016-05-29 10:24:44 -07:00
By default, Consul DNS queries will return a node's local address, even when
2016-02-07 10:56:47 -08:00
being queried from a remote datacenter. If you need to use a different address
to reach a node from outside its datacenter, you can configure this behavior
2022-01-10 17:30:50 -08:00
using the [`advertise-wan`](/docs/agent/config/cli-flags#_advertise-wan) and
[`translate_wan_addrs`](/docs/agent/config/config-files#translate_wan_addrs) configuration
2016-02-07 10:56:47 -08:00
options.
2019-12-09 21:26:41 -05:00
2021-08-12 13:49:33 -04:00
## DNS with ACLs
In order to use the DNS interface when
2022-05-09 09:04:23 -07:00
[Access Control Lists (ACLs)](/docs/security/acl)
2021-08-12 13:49:33 -04:00
are enabled, you must first create ACL tokens with the necessary policies.
Consul agents resolve DNS requests using one of the preconfigured tokens below,
listed in order of precedence:
2022-01-10 17:30:50 -08:00
1. The agent's [`default` token](/docs/agent/config/config-files#acl_tokens_default).
2022-05-09 09:04:23 -07:00
2. The built-in [`anonymous` token](/docs/security/acl/acl-tokens#built-in-tokens).
2021-08-12 13:49:33 -04:00
Because the anonymous token is used when any request is made to Consul without
explicitly specifying a token, production deployments should not apply policies
needed for DNS to this token.
Consul will either accept or deny the request depending on whether the token
has the appropriate authorization. The following table describes the available
DNS lookups and required policies when ACLs are enabled:
2021-12-14 11:39:17 -08:00
| Lookup | Type | Description | ACLs Required |
| ------------------------------------------------------------------------------ | -------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `*.node.consul` | [Node](#node-lookups) | Allow resolving DNS requests for the target node (i.e., `<target>.node.consul`) | [`node:read`](/docs/security/acl/acl-rules#node-rules) |
| `*.service.consul`, `*.connect.consul`, `*.ingress.consul`, `*.virtual.consul` | [Service: standard](#service-lookups) | Allow resolving DNS requests for target service (e.g., `<target>.service.consul`) instances running on ACL-authorized nodes | [`service:read`](/docs/security/acl/acl-rules#service-rules), [`node:read`](/docs/security/acl/acl-rules#node-rules) |
2022-03-30 16:16:26 -05:00
| `*.query.consul` | [Service: prepared query](#prepared-query-lookups) | Allow resolving DNS requests for [service instances specified](/api-docs/query#service-1) by the target prepared query (i.e., `<target>.query.consul`) running on ACL-authorized nodes | [`query:read`](/docs/security/acl/acl-rules#prepared-query-rules), [`service:read`](/docs/security/acl/acl-rules#service-rules), [`node:read`](/docs/security/acl/acl-rules#node-rules) |
2021-08-12 13:49:33 -04:00
For guidance on how to configure an appropriate token for DNS, refer to the
securing Consul with ACLs guides for:
2022-09-06 08:35:01 -07:00
- [Production Environments](https://learn.hashicorp.com/tutorials/consul/access-control-setup-production#token-for-dns)
- [Development Environments](https://learn.hashicorp.com/tutorials/consul/access-control-setup?utm_source=docs#enable-acls-on-consul-clients)