DNS Cache · 2 min read · Oct 03, 2025
Criando um Cache DNS com djbdns
Criando um Cache DNS com djbdns
Construir um cache DNS local acelerará sua conexão com a internet, uma vez que o tempo para o “trabalho de tradução” (converter nomes de domínio em endereços IP) se tornará negligenciável, assumindo que o cache DNS obtenha as informações do DNS pai.
FreeBSD já inclui o bind em cada lançamento, mas eu prefiro usar o djbdns.
Forma simples de construir um cache DNS local no FreeBSD usando ports:
1. Instalar os ports do djbdns
su-2.05b# whereis djbdns
djbdns: /usr/ports/dns/djbdns
su-2.05b# cd /usr/ports/dns/djbdns && make install cleanBasta pressionar OK e o processo de instalação começará.
2. Configuração
# pw groupadd nofiles -g 800
# pw useradd dnslog -g nofiles -u 810 -d /nonexistent -s /sbin/nologin
# pw useradd dnscache -g nofiles -u 811 -d /nonexistent -s /sbin/nologinEsses comandos adicionarão o grupo nofiles e os usuários dnslog e dnscache.
# dnscache-conf dnscache dnslog /etc/dnscache 127.0.0.1
# ln -s /etc/dnscache /var/service
# echo ‘nameserver 127.0.0.1? >/etc/resolv.confEsses comandos farão com que o endereço IP 127.0.0.1 seja um cache DNS “apenas” para aquele computador.
Para podermos usar o cache DNS em nossa rede, precisamos emitir mais comandos:
# dnscache-conf dnscache dnslog /etc/dnscache 192.168.1.1
# touch /etc/dnscache/root/ip/192.168.1
# ln -s /etc/dnscache /var/serviceAgora, cada cliente pode adicionar 192.168.1.1 como um resolvedor DNS válido:
Para usar o poder do “daemontools”, precisamos adicionar esta entrada em rc.conf:
svscan_enable="YES"Na primeira vez, precisamos iniciá-lo manualmente:
su-2.05b# /usr/local/etc/rc.d/svscan.sh startVerifique se o serviço está em execução:
su-2.05b# ps -ax | grep dns338 ?? I 0:00.03 supervise dnscache
90515 ?? S 0:03.51 /usr/local/bin/dnscachePara verificar se o dnscache “realmente funciona”:
su-2.05b# tail -f /etc/dnscache/log/main/currentExemplo de saída:
su-2.05b# tail -f /etc/dnscache/log/main/current
@4000000046375a22168f3ee4 cached 1 i.gtld-servers.net.
@4000000046375a22168fcf6c cached 1 j.gtld-servers.net.
@4000000046375a2216905ff4 cached 1 k.gtld-servers.net.
@4000000046375a221690ec94 cached 1 l.gtld-servers.net.
@4000000046375a2216917d1c cached 1 m.gtld-servers.net.
@4000000046375a22169209bc cached 1 a.gtld-servers.net.
@4000000046375a221692c154 cached 1 b.gtld-servers.net.
@4000000046375a22169351dc cached 1 c.gtld-servers.net.
@4000000046375a221693de7c cached 1 d.gtld-servers.net.
@4000000046375a2216945794 tx 0 255 mx44.alanistz.com. com. c005061e c0304f1e c036701e c023331e c037531e c02a5d1e c01a5c1e c0210e1e c029a21e c00c5e1e c02bac1e c01f501e c034b21e
@4000000046375a222673d964 rr cc4a7021 86400 1 mx74mi.clarmu.info. d035034a
@4000000046375a2226787514 rr cc4a7021 86400 1 mx144pb.clarmu.info. 42212090
@4000000046375a222678889c rr cc4a7021 86400 1 mx174hi.clarmu.info. 42f890ae
@4000000046375a222678983c rr cc4a7021 86400 1 mx187tr.clarmu.info. 416f11bb
@4000000046375a222678abc4 rr cc4a7021 86400 1 mx204pa.clarmu.info. 42217dcc
@4000000046375a222678bb64 rr cc4a7021 86400 ns clarmu.info. mx74mi.clarmu.info.
@4000000046375a222678ceec rr cc4a7021 86400 ns clarmu.info. mx204pa.clarmu.info.
@4000000046375a222678de8c rr cc4a7021 86400 ns clarmu.info. mx187tr.clarmu.info.
@4000000046375a222679059c rr cc4a7021 86400 ns clarmu.info. mx174hi.clarmu.info.
@4000000046375a222679153c rr cc4a7021 86400 ns clarmu.info. mx144pb.clarmu.info.
@4000000046375a22267924dc stats 379 144625 13 0
@4000000046375a2226793864 cached 1 mx74mi.clarmu.info.
@4000000046375a2226794804 cached 1 mx204pa.clarmu.info.
@4000000046375a22267957a4 cached 1 mx187tr.clarmu.info.
@4000000046375a2226796744 cached 1 mx174hi.clarmu.infoParabéns, seu cache DNS está funcionando bem.
Receba novas postagens na sua caixa de entrada
Sem spam. Cancele a assinatura a qualquer momento.