(module-dhcp)= # DHCP Configuration Module DHCP configuration module implements DHCP clients, servers, and relays for IPv4 and IPv6. ```eval_rst .. contents:: Table of Contents :depth: 2 :local: :backlinks: none ``` (dhcp-platform)= ## Platform Support DHCP clients are supported on these platforms: | Operating system | IPv4 | IPv6 | Default
route | Routing over
DHCP interfaces | | --------------------- | :-: | :-: | :-: | :-: | | Arista EOS | ✅ [❗](caveats-eos) | ❌ | ✅ | ❌ [❗](caveats-eos) | | Cisco IOSv/IOSvL2 | ✅ | ✅ | ✅ | ✅ | | Cisco IOS XE[^18v] | ✅ | ✅ | ✅ | ✅ | | Cumulus Linux | ✅ | ✅ | ❌ | ✅ | | Linux (Ubuntu VM only)| ✅ | ✅ | ❌ | ❌ | [^18v]: Includes Cisco CSR 1000v, Cisco Catalyst 8000v, Cisco IOS-on-Linux (IOL), and IOL Layer-2 image. DHCP servers are supported on these platforms: | Operating system | IPv4 | IPv6 | VRF-aware | | --------------------- | :-: | :-: | :-: | | Arista EOS | ✅ | ✅ | ❌ | | Cisco IOSv/IOSvL2 | ✅ | ✅ | ❌ | | Cisco IOS XE[^18v] | ✅ | ✅ | ✅ | | dnsmasq | ✅ | ✅ | ❌ | | Linux (Ubuntu VM only)| ✅ | ✅ | ❌ | DHCP relays are supported on these platforms: | Operating system | IPv4 | IPv6 | VRF-aware | | --------------------- | :-: | :-: | :-: | Arista EOS | ✅ | ✅ | ✅ [❗](caveats-eos) | | Cisco IOSv/IOSvL2 | ✅ | ✅ | ✅ | | Cisco IOS XE[^18v] | ✅ | ✅ | ✅ | | Cumulus Linux | ✅ [❗](linux-dhcp-relay) | ❌ | ❌ | | Linux (Ubuntu VM only)| ✅ [❗](linux-dhcp-relay) | ❌ | ❌ | ```{tip} * VRF-aware DHCP relays use DHCP options specified in RFC 6607. * VRF-aware DHCP servers can use DHCP options specified in RFC 6607 to select the client subnet. ``` (dhcp-parameters)= ## Node Parameters The DHCP module supports the following node parameters: * **dhcp.server** (boolean) -- the device should run a DHCP server * **dhcp.vrf** (boolean) -- the DHCP relay or server should be VRF-aware. The default value of this parameter is set to _true_ if the node performs inter-VRF DHCP relaying or has DHCP pools from VRF subnets. You can override that behavior by setting **dhcp.vrf** to _false_. ```{tip} You have to set **‌dhcp.vrf** to _False_ on a Cisco IOS XE DHCP server when you use it with Arista EOS VRF-aware relays ([more details](https://blog.ipspace.net/2023/03/netlab-vrf-dhcp-relay.html)). ``` (dhcp-parameters-link)= ## Link Parameters You can enable the DHCP client on all non-relaying devices attached to a link with the boolean **dhcp.client.ipv4** link attribute and the DHCPv6 client with the boolean **dhcp.client.ipv6** attribute. ```{warning} * While you can use the **‌dhcp.client** parameter to enable DHCP for all hosts attached to a VLAN segment ([see example](dhcp-vlan-example)), do not use DHCP on [routed VLANs](vlan-addressing-routed). * You cannot use **‌dhcp.client** link/VLAN parameter to enable the DHCP client on a VLAN interface. You have to enable the DHCP client on an IRB VLAN interface within the node **‌vlans** dictionary ([more details](vlan-interface-parameters)). ``` ## Interface Parameters * To start a DHCP client on an interface, set the **ipv4** or **ipv6** address to **dhcp**. You can use the **dhcp.client.ipv4** or the **dhcp.client.ipv6** interface attribute only when the node already uses the DHCP module. * The DHCP client usually installs a default route to an IPv4 default gateway[^DGv6] sent in a DHCP reply. To turn off this functionality, set **dhcp.client.default** interface parameter to `False`. * To start a DHCP relay on an interface, set the **dhcp.server** interface parameter to a list of DHCP servers (node names). The nodes listed in the **dhcp.server** parameter must have the **dhcp.server** node attribute set. An interface running a DHCP relay cannot use a DHCP client, the **dhcp.client** attribute (when specified) is removed from the interface. * To enable inter-VRF DHCP relaying, set the **dhcp.vrf** interface parameter to the name of the destination VRF (or **global**). [^DGv6]: DHCPv6 does not have a *default gateway* option. IPv6 needs _router advertisements_ generated by an adjacent router. ## Implementation Notes * The **dhcp** module is automatically enabled for nodes with DHCP clients. You don't have to specify it in the **module** list. However, at least one topology node must use the **dhcp** module to enable _netlab_ to recognize **dhcp** as a valid IPv4 or IPv6 address. * You must enable the **dhcp** module on DHCP relays and servers. * *dnsmasq* always uses the **dhcp** module and is configured as a DHCP server. There's no need to set the **module** or **dhcp.server** node variable. ## Examples The following topology starts IPv4 DHCP clients on Cumulus Linux and Cisco IOSv and a DHCP server on Arista EOS: ``` nodes: r1: device: iosv r2: device: cumulus srv: device: eos module: [ dhcp ] dhcp.server: True links: - r1: ipv4: dhcp r2: ipv4: dhcp srv: ``` The following topology uses *dnsmasq* DHCP server and starts IPv4 and IPv6 DHCP clients on Arista EOS: ``` provider: clab addressing.lan.ipv6: 2001:db8:cafe::/48 nodes: client: device: eos server: device: dnsmasq links: - client: ipv4: dhcp ipv6: dhcp server: ``` The following topology uses DHCP relaying on an Arista EOS switch to propagate DHCP requests from Cumulus Linux clients to a *dnsmasq* DHCP server. ``` provider: clab module: [ dhcp ] nodes: client: device: cumulus relay: device: eos server: device: dnsmasq links: - client: ipv4: dhcp relay: dhcp.server: server - relay-server ``` (dhcp-vlan-example)= The following example enables the DHCP client on all hosts attached to a VLAN and the DHCP relay on the access switch: ``` provider: libvirt defaults.device: eos vlans: red: dhcp.client.ipv4: True links: [ s1-h1, s1-h2 ] nodes: s1: module: [ dhcp, vlan ] vlans: red: dhcp.server: dhs h1: device: linux h2: device: linux dhs: device: dnsmasq provider: clab links: - s1-dhs ```