coredns/plugin/bufsize
Kohei Yoshida 8cc034eece plugin/bufsize: add usecase description (#3437)
* add usecase

Signed-off-by: yukihira <yukihira.lab@gmail.com>

* fix some comments

Signed-off-by: ykhr53 <yukihira.lab@gmail.com>
2019-11-14 07:37:45 +00:00
..
bufsize.go Add bufsize plugin for preparing the DNS Flag Day and avoiding IP fragmentation (#3401) 2019-11-10 08:10:12 +00:00
bufsize_test.go Add bufsize plugin for preparing the DNS Flag Day and avoiding IP fragmentation (#3401) 2019-11-10 08:10:12 +00:00
OWNERS add OWNERS file (#3441) 2019-11-13 09:49:24 +00:00
README.md plugin/bufsize: add usecase description (#3437) 2019-11-14 07:37:45 +00:00
setup.go Add bufsize plugin for preparing the DNS Flag Day and avoiding IP fragmentation (#3401) 2019-11-10 08:10:12 +00:00
setup_test.go Add bufsize plugin for preparing the DNS Flag Day and avoiding IP fragmentation (#3401) 2019-11-10 08:10:12 +00:00

bufsize

Name

bufsize - sizes EDNS0 buffer size to prevent IP fragmentation.

Description

bufsize limits a requester's UDP payload size.
It prevents IP fragmentation so that to deal with DNS vulnerability.

Syntax

bufsize [SIZE]

[SIZE] is an int value for setting the buffer size.
The default value is 512, and the value must be within 512 - 4096.
Only one argument is acceptable, and it covers both IPv4 and IPv6.

Examples

Enable limiting the buffer size of outgoing query to the resolver (172.31.0.10):

. {
    bufsize 512
    forward . 172.31.0.10
    log
}

Enable limiting the buffer size as an authoritative nameserver:

. {
    bufsize 512
    file db.example.org
    log
}

Considerations

  • Setting 1232 bytes to bufsize may avoid fragmentation on the majority of networks in use today, but it depends on the MTU of the physical network links.
  • For now, if a client does not use EDNS, this plugin adds OPT RR.