Skip to content

Commit

Permalink
contrib: Update DNS table description
Browse files Browse the repository at this point in the history
  • Loading branch information
dnephin committed Jun 23, 2021
1 parent 111cbe0 commit e000c0a
Showing 1 changed file with 22 additions and 15 deletions.
37 changes: 22 additions & 15 deletions contributing/service-discovery/dns.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,19 +24,26 @@ the DNS protocol can be found in the RFCs: [RFC 1035], [RFC 6891], [RFC 2782], a
The DNS interface is implemented as a DNS server using [miekg/dns] and the handlers for
requests are in `agent/dns.go`.

The following table describe the current DNS behaviour depending on the dns query kind (node, service...), and the query type (A/AAAA, SRV...)

| | service | connect (enterprise) | ingress (enterprise) | node | query | addr |
|----------------|-------------------------|-------------------------|-------------------------|------------------------|-----------------|------------------------------|
| TypeSOA | Supported | Supported | Supported | Supported | Supported | Supported |
| TypeNS | Supported | Supported | Supported | Supported | Supported | Supported |
| TypeAXFR | Not Implemented | Not Implemented | Not Implemented | Not Implemented | Not Implemented | Not Implemented |
| TypeA/TypeAAAA | Supported | Supported | Supported | Supported | | Supported |
| TypeANY | Supported (return A) | Supported (return A) | Supported (return A) | Supported | | Supported (return A) |
| TypeCNAME | Supported (node cname) | Supported (node cname) | Supported (node cname) | Supported (node cname) | | return empty with A as extra |
| TypeOPT | Supported (node OPT) | Supported (node OPT) | Supported (node OPT) | Supported (node OPT) | | return empty with A as extra |
| TypePTR | Supported (node PTR) | Supported (node PTR) | Supported (node PTR) | Supported (node PTR) | | return empty with A as extra |
| TypeSRV | Supported (service SRV) | Supported (service SRV) | Supported (service SRV) | No error but empty | | return empty with A as extra |
| TypeTXT | Answer A record (????) | Answer A record (????) | Answer A record (????) | Supported | | return empty with A as extra |

[miekg/dns]: https://github.com/miekg/dns

## DNS Queries and Records

The DNS interface handles queries where OPCODE=0 (standard query). The following table describe the current
DNS behaviour for different record types and domain names. The Domain names (along the
top) are always in the form `<prefix>.<name in table>.<domain>`, where `domain` is
generally documented as `consul` but can be set using the `domain` or `alt_domain` config
fields. The `prefix` is an identifier (service name, node name, prepared query name, etc).

| Type | service | connect | ingress | node | query | addr |
|---------|-------------------------|-------------------------|-------------------------|------------------------|-----------------|------------------------------|
| SOA | Supported | Supported | Supported | Supported | Supported | Supported |
| NS | Supported | Supported | Supported | Supported | Supported | Supported |
| AXFR | Not Implemented | Not Implemented | Not Implemented | Not Implemented | Not Implemented | Not Implemented |
| A/AAAA | Supported | Supported | Supported | Supported | | Supported |
| ANY | Supported (return A) | Supported (return A) | Supported (return A) | Supported | | Supported (return A) |
| CNAME | Supported (node cname) | Supported (node cname) | Supported (node cname) | Supported (node cname) | | return empty with A as extra |
| OPT | Supported (node OPT) | Supported (node OPT) | Supported (node OPT) | Supported (node OPT) | | return empty with A as extra |
| PTR | Supported (node PTR) | Supported (node PTR) | Supported (node PTR) | Supported (node PTR) | | return empty with A as extra |
| SRV | Supported (service SRV) | Supported (service SRV) | Supported (service SRV) | No error but empty | | return empty with A as extra |
| TXT | Answer A record (????) | Answer A record (????) | Answer A record (????) | Supported | | return empty with A as extra |

0 comments on commit e000c0a

Please sign in to comment.