Por que o dnsmasq está encaminhando endereços já resolvidos?

2

Eu posso fazer ping no host:

dig registry.mynet

E o servidor DNS faz o que é esperado:

dnsmasq[1]: 895 127.0.0.1/44580 query[A] registry.mynet from 127.0.0.1
dnsmasq[1]: 895 127.0.0.1/44580 /etc/hosts registry.mynet is 42.42.42.42

Mas se eu tentar uma solicitação mais complexa, levará muito tempo:

» time http -h http://registry.mynet/v2/_catalog?n=100
HTTP/1.1 200 OK
Connection: keep-alive
Content-Length: 97
Content-Type: application/json; charset=utf-8
Date: Fri, 23 Mar 2018 10:42:13 GMT
Docker-Distribution-Api-Version: registry/2.0
Server: nginx/1.13.9
X-Content-Type-Options: nosniff

real    0m15.297s
user    0m0.252s
sys     0m0.028s

E isso não tem nada a ver com o serviço (que é muito responsivo). Isso ocorre porque o servidor DNS faz algo estranho:

dnsmasq[1]: 887 127.0.0.1/53345 query[A] registry.mynet from 127.0.0.1
dnsmasq[1]: 887 127.0.0.1/53345 /etc/hosts registry.mynet is 42.42.42.42
dnsmasq[1]: 888 127.0.0.1/53345 query[AAAA] registry.mynet from 127.0.0.1
dnsmasq[1]: 888 127.0.0.1/53345 forwarded registry.mynet to 208.67.220.220
dnsmasq[1]: 888 127.0.0.1/53345 forwarded registry.mynet to 8.8.4.4
dnsmasq[1]: 888 127.0.0.1/53345 forwarded registry.mynet to 8.8.8.8
dnsmasq[1]: 888 127.0.0.1/53345 forwarded registry.mynet to 8.8.8.8

dnsmasq[1]: 889 127.0.0.1/53345 query[A] registry.mynet from 127.0.0.1
dnsmasq[1]: 889 127.0.0.1/53345 /etc/hosts registry.mynet is 42.42.42.42
dnsmasq[1]: 890 127.0.0.1/53345 query[AAAA] registry.mynet from 127.0.0.1
dnsmasq[1]: 890 127.0.0.1/53345 forwarded registry.mynet to 208.67.220.220
dnsmasq[1]: 890 127.0.0.1/53345 forwarded registry.mynet to 8.8.4.4
dnsmasq[1]: 890 127.0.0.1/53345 forwarded registry.mynet to 8.8.8.8
dnsmasq[1]: 890 127.0.0.1/53345 forwarded registry.mynet to 8.8.8.8

dnsmasq[1]: 891 127.0.0.1/41484 query[A] registry.mynet from 127.0.0.1
dnsmasq[1]: 891 127.0.0.1/41484 /etc/hosts registry.mynet is 42.42.42.42
dnsmasq[1]: 892 127.0.0.1/58752 query[AAAA] registry.mynet from 127.0.0.1
dnsmasq[1]: 892 127.0.0.1/58752 forwarded registry.mynet to 208.67.220.220
dnsmasq[1]: 892 127.0.0.1/58752 forwarded registry.mynet to 8.8.4.4
dnsmasq[1]: 892 127.0.0.1/58752 forwarded registry.mynet to 8.8.8.8
dnsmasq[1]: 892 127.0.0.1/58752 forwarded registry.mynet to 8.8.8.8

Eu tenho duas perguntas:

  • o servidor DNS encontra a resposta correta ( /etc/hosts registry.mynet is 42.42.42.42 ): por que o processamento continua?
  • o que significam as entradas "encaminhadas"?
por DanMetro 23.03.2018 / 11:56

1 resposta

1

Primeiro de tudo:

dig registry.mynet

Realiza somente consultas IPv4 ( [A] consultas). Seu dnsmasq está respondendo bem a essas consultas. Você pode forçar dig a fazer AAAA consultas fazendo:

dig registry.mynet AAAA

Nos registros, você pode ver que http está enviando consultas IPv4 e IPv6 ( [AAAA] consultas). Seu dnsmasq está respondendo ao primeiro, mas não o último, talvez porque você não configurou endereços IPv6 para seus hosts.

Você pode evitar isso certificando-se de que dnsmasq não está encaminhando solicitações de hosts em sua rede:

local=/mynet/
    
por 23.03.2018 / 13:57