Dnsmasq resolve o nome do host local para 127.0.0.1 em toda a rede

8

Meu dnsmasq está configurado:

  • No host 'rtfm.lan'
  • Domínio 'lan'
  • Existem algumas predefinições de DHCP que incluem nomes de host

Todos os hosts '* .lan' registrados via DHCP resolvem bem: o dnsmasq sabia quais IPs são atribuídos a quais nomes de host. No entanto, 'rtfm.lan' é lido em / etc / hosts e resolvido para 127.0.0.1.

Posso impedir que o dnsmasq leia / etc / hosts e adicione um endereço manualmente:

no-hosts
address=/rtfm.lan/192.168.1.2

Mas isso não é flexível: se um dia eu decidir mudar meu IP - também terei que alterá-lo no dnsmasq.conf.

Como posso dizer ao dnsmasq para usar o nome do host local com seu IP real?


Apenas no caso .. aqui está a minha configuração DNSmasq:

# Never forward plain names (without a dot or domain part)
domain-needed
# Never forward addresses in the non-routed address spaces.
bogus-priv
# Read resolv.conf serially
strict-order

#==========[ NAMESERVER ]==========#

# Cache size
cache-size=4096
# Don't read /etc/hosts
no-hosts
# Read additional hosts-file (not only /etc/hosts) to add entries into DNS
addn-hosts=/etc/hosts-dnsmasq
# Auto-append <domain> to simple entries in hosts-file
expand-hosts

#=== HOSTNAME OVERRIDES
address=/localhost/127.0.0.1 # *.localhost => 127.0.0.1

#==========[ DHCP ]==========#
# Enable for the local network?
dhcp-authoritative
# Tell MS Windows to release a lease on shutdown
dhcp-option=vendor:MSFT,2,1i

#=== DHCP
# Domain name
domain=lan
# DNS-resolve hosts in these domains ONLY from /etc/hosts && DHCP leases
local=/lan/

# DHCP range & lease time
dhcp-range=192.168.1.70,192.168.1.89,24h 
# Default route
dhcp-option=3,192.168.1.1

#=== FIXED LEASES
# LAN MY HOSTS
dhcp-host=00:23:54:5d:27:fa,                    rtfm.lan,               192.168.1.2
dhcp-host=00:23:54:5d:27:fb,                    rtfm.lan,               192.168.1.2
dhcp-host=c8:0a:a9:45:f1:03, 00:1e:64:9e:e9:5e, wtf.lan,                192.168.1.3
Kolypto
fonte

Respostas:

10

Normalmente, você definiria seus hosts estáticos /etc/hostse ativaria hostsem seu dnsmasq.confarquivo. dnsmasqpermite especificar um nome alternativo para este arquivo.

Se você deseja rtfm.lanser endereçado 192.168.1.2, adicione uma linha 192.168.1.2 rtfm.lanpara /etc/hosts. Normalmente, o arquivo hosts do dnsmasq deve ser portátil para todos os servidores.

Na rtfm.lanpilha de IP, um curto-circuito será direcionado e não enviará tráfego para a rede.

Se você atualizar seu /etc/hostsarquivo e sinalizar dnsmasqcom um HUPsinal, o arquivo hosts será relido e as alterações aplicadas.

EDIT: dnsmasq não foi projetado para servir um endereço de host dinâmico para seu próprio host. Conforme observado, ele fornece nomes de seu arquivo de concessão para clientes DHCP.

Se o seu host for um gateway da Internet, normalmente ele serviria um endereço estático local. A entrega do endereço do gateway da Internet pode causar problemas de roteamento e firewall.

Você pode configurar seu cliente DHCP para gravar um arquivo de hosts de uma linha. A opção dnsmasq addn-hostpode ser usada para que o dnsmasq leia esse arquivo além de /etc/hosts. Se o endereço provavelmente mudar, o cliente DHCP poderá reescrever o arquivo e enviar ao dnsmasq um HUPsinal na alteração do endereço IP.

BillThor
fonte
Então .. não há como fazer com que o dnsmasq use o IP atual buscado na interface?
Kolypto
Não é por padrão, mas você pode obter o seu cliente DHCP para fornecer os dados necessários. Não sei por que você estaria servindo um endereço dinâmico para o host do dnsmasq.
BillThor
4

O dnsmasq pode resolver seu próprio nome de host, desativando a leitura de / etc / hosts e configurando outro arquivo de configuração para ler os nomes de host, incluindo ele próprio.

Configuração do dnsmasq (/etc/dnsmaq.conf):

no-hosts
addn-hosts=/etc/dnsmasq_hosts

Em / etc / dnsmasq_hosts, configure o próprio ponto de nome do host para o endereço IP necessário (assim como outros nomes de host na LAN local).

pnail
fonte