[nsd-users] Wrong source IP for reply if 'ip-address' is not specified

Anand Buddhdev anandb at ripe.net
Wed Dec 13 23:12:55 CET 2017


On 13/12/2017 22:26, Paul Wouters wrote:

Hi Paul,

> We have a different opinion on what is "normal behaviour". I believe the
> normal behaviour is to reply using the IP address you received the
> packet from, eg using:
> 
> err = setsockopt(s, SOL_IP, IP_PKTINFO, &opt, sizeof(opt));
> 
> or
> 
> err = setsockopt(s, IPPROTO_IP, IP_RECVDSTADDR, &opt, sizeof(opt));

I don't know if these options are available in non-Linux socket
implementations, and is probably the reason that NSD doesn't use them.
But I'm sure Wouter can comment more definitively.

I know the questions will come, so let me try to anticipate them and
answer them. Someone might ask why this isn't necessary with BIND. This
is because BIND attempts to detect the capability of the OS it's running
on, and compensate for the cases where these advanced options are not
present. This may make it easier for an operator, but at the expense of
more code complexity. I really do prefer NSD's simpler approach.

Note also that in nsd.conf, this cause is very clearly noted. From nsd.conf:

ip-address: <ip4 or ip6>[@port]
    NSD will bind to the listed ip-address. Can be give multiple times
    to bind multiple ip-addresses. Optionally, a port number can be
    given.   If  none  are  given  NSD listens to the wildcard
    interface. Same as commandline option -a.  For servers with multiple
    IP addresses that can be used to send traffic to the internet, list
    them one by one, or the source address of replies could be wrong.

    This is because if the udp socket associates a source address of
    0.0.0.0 then the kernel picks an ip-address with which to send to
    the internet, and it picks the wrong one.  Typically needed for
    anycast  instances.   Use  ip-transparent  to  be  able  to  list
    addresses that turn on later (typical for certain load-balancing).

Regards,
Anand


More information about the nsd-users mailing list