Multiple chrooted dhcp servers for vlans on Linux?

stevel_isc at stevel_isc at
Fri Feb 26 20:41:22 UTC 2016

Thank you both for the replies.

I was afraid of this, but pretty much expected that was the case.

-----Original Message-----
From: dhcp-users-bounces at
[mailto:dhcp-users-bounces at] On Behalf Of Chuck Anderson
Sent: Friday, February 26, 2016 12:22 PM
To: dhcp-users at
Subject: Re: Multiple chrooted dhcp servers for vlans on Linux?

This won't work unless you use separate full virtual machines...

You could make it work on a single machine maybe, but you'd need to
recompile the dhcpd with USE_SOCKETS.  Then dhcpd will only work to
serve remote clients via a relay agent, not local clients directly
connected to the same VLAN as the server.  This is because local
clients must be served via a raw socket rather than a normal udp
socket.  The reason is that responses to local, on-link clients must
contain specific IP headers and MAC address headers that cannot be set
via a regular udp socket, such as the all-ones broadcast address.  I
may have the exact details wrong, but that is the gist of it.

On Fri, Feb 26, 2016 at 10:51:41AM -0800, stevel_isc at wrote:
> The goal is to have multiple chrooted dhcpd processes, one for each of
> vlans, such that a compromise of a more public one won't affect a more
> private one.
> Server version is isc-dhcpd-4.3.3-P1 and Linux is a recent install of
> Debian.
> I've got them all running but looking at dhcpd processes in netstat I
> think it'll actually work in practice.  
> Even though each one is specified to a particular vlan interface they all
> appear to be listening to and I see nothing visible
> them.
> Are they really all listing on every vlan, and does that mean incoming
> requests over one vlan will be handled by whatever server happens to grab
> the request (3 out of 4 chance it's the wrong one)?
dhcp-users mailing list
dhcp-users at

More information about the dhcp-users mailing list