Help us improve your experience.

Let us know what you think.

Do you have time for a two-minute survey?

 
 

DHCP 侦听

动态主机配置协议 (DHCP) 侦听通过验证来自连接到路由器、交换机或防火墙的不受信任设备的 DHCP 消息来增强网络安全,并防止未经授权的 DHCP 服务器在不受信任的端口上发送 DHCPOFFER 数据包。

DHCP 侦听支持

动态主机配置协议 (DHCP) 是 TCP/IP 网络中使用的一种网络管理协议,用于动态地将 IP 地址和其他相关配置信息分配给网络设备。

DHCP 侦听的工作原理

动态主机配置协议 (DHCP) 将 IP 地址动态分配给设备,租用地址可在不再需要时重复使用。需要通过 DHCP 地址的主机或终端设备必须通过 LAN 与 DHCP 服务器进行通信。

下图显示了 DHCP 侦听过程。

图 1:DHCP 侦听 DHCP Snooping

在拓扑中,最终用户设备连接到 Junos OS 设备(路由器、交换机或防火墙)。Junos OS 设备可以连接到 DHCP 客户端和 DHCP 服务器。配置为 DHCP 中继代理的 Junos OS 设备充当 DHCP 客户端与 DHCP 服务器之间的接口。此 Junos OS 设备检查 DHCP 数据包。DHCP 服务器将 IP 地址分配给客户端。

Junos OS 设备上的 DHCP 侦听功能可以执行以下操作:

  • 验证从不受信任的来源收到的 DHCP 消息,并过滤掉无效消息。
  • 提取租给每个客户端的 IP 地址并构建数据库。DHCP 侦听数据库(或绑定表)包含有关每个 DHCP 客户端的 IP 地址、MAC 地址和 VLAN 的信息。
  • 使用 DHCP 侦听绑定表验证来自不受信任主机的后续请求。通过验证 DHCP 请求是否来自可信来源,瞻博网络设备可以确保仅处理有效的 DHCP 请求。

这样,DHCP 侦听通过跟踪可信 DHCP 服务器(连接到可信网络端口的服务器)分配给下游网络设备的有效 IP 地址,充当网络安全的守护者。

DHCPv6 中继代理侦听

DHCPv6 中继代理通过在 IPv6 网络中提供支持来增强 DHCP 中继代理。DHCPv6 中继代理在 DHCPv6 客户端和 DHCPv6 服务器之间传递消息,类似于 DHCP 中继代理支持 IPv4 网络的方式。在客户端和服务器之间有多个 DHCPv6 中继代理的多中继拓扑中,窥探使中间的中继代理能够正确处理来自客户端的单播流量并将其转发到服务器。此拓扑中的窥探涉及以下操作:

  • DHCPv6 中继代理使用带有 UDP 端口 547(即 DHCPv6 UDP 服务器端口)的过滤器,按转发表来窥探传入的单播 DHCPv6 数据包。
  • 然后,DHCPv6 中继代理处理过滤器截获的数据包,并将这些数据包转发到 DHCPv6 服务器。

DHCP 侦听的优势

  • DHCP 侦听可以通过过滤 IP 地址来提供额外的安全层。过滤过程会评估网络流量,以允许来自已验证且有效的 IP 地址进行通信。
  • DHCP 侦听可以通过过滤掉到达错误端口或内容不正确的 DHCP 数据包,防止网络中的恶意 DHCP 活动。

示例:配置 DHCP 中继代理的 DHCP 侦听支持

此示例说明如何配置对 DHCP 中继代理的 DHCP 侦听支持。

要求

概述

在此示例中,您可以通过完成以下操作来配置对 DHCP 中继代理的 DHCP 侦听支持:

  • 覆盖默认的 DHCP 侦听配置,并为组 frankfurt中的接口启用 DHCP 侦听支持。

  • 将 DHCP 中继代理配置为仅将窥探的数据包转发至已配置的接口。

配置

程序

分步过程

要配置 DHCP 侦听的 DHCP 中继支持:

  1. 指定要配置 DHCP 中继代理。

  2. 指定支持 DHCP 侦听的已命名接口组。

  3. 指定要包含在组中的接口。DHCP 中继代理在确定是转发还是丢弃流量时,会将这些接口视为配置的接口。

  4. 指定要覆盖组的默认配置。

  5. 为组启用 DHCP 侦听支持。

  6. 返回 [edit forwarding-options dhcp-relay] 层级以配置转发操作,并指定 DHCP 中继代理仅在配置的接口上转发获窥探的数据包:

  7. 为 DHCP 中继代理启用 DHCP 侦听数据包转发。

  8. 指定仅在配置的接口(组 frankfurt中的接口)上转发窥探的数据包。

结果

在配置模式下,输入 show forwarding-options 命令以确认您的配置。如果输出未显示预期的配置,请重复此示例中的说明进行更正。以下输出还显示了法兰克福组中一系列已配置的接口。

如果完成设备配置,请从配置模式输入 commit

启用 DHCP 侦听

在 Junos OS 设备上,为特定 VLAN 配置 DHCP 安全性、DHCP 中继、DHCP 服务器设置或路由实例时,DHCP 侦听功能会自动启用。

请注意,在 Junos OS 设备上,不能将 DHCP 侦听配置为独立功能。

当您配置以下任一或全部功能时,Junos OS 可在交换机、路由器或防火墙上启用 DHCP 侦听:

  • 以下层级的 DHCP 中继或 DHCP 本地服务器选项:
    • dhcp-relay[edit routing-instances routing-instance-name forwarding-options] 层次[edit forwarding-options]结构级别的语句。
    • dhcp-local-server[edit routing-instances routing-instance-name system services] 层次[edit system services]结构级别的语句。
      注意:

      配置 DHCP 中继时,请使用该 forward-only 语句,除非您需要订阅者管理或服务等级 (CoS)。该 forward-only 配置转发指定的 DHCP 客户端数据包,而不创建订阅者会话。

  • 特定 VLAN 上的 DHCP 安全会激活该 VLAN 的 DHCP 侦听:

    交换机层次[edit vlans vlan-name forwarding-options]结构级别的 dhcp-security 语句。

  • dhcp-security路由器层次[edit bridge-domains bridge-domain-name forwarding-options dhcp-security]结构级别的语句。
  • 您可以将 DHCP 本地服务器配置为转发或丢弃所有接口、仅配置的接口或仅未配置的接口的侦听数据包。有关详细信息,请参阅 配置 DHCP 本地服务器的 DHCP 侦听数据包转发支持

转发 DHCP 中继代理的 DHCP 侦听数据包

您可以使用语 forward-snooped-clients 句进一步细化对 DHCP 侦听行为的控制。

您可以使用语 forward-snooped-clients 句根据接口配置来决定是转发还是丢弃受监控的流量。

  1. 要评估侦听的流量并在以后决定是转发还是丢弃流量,请在 [edit forwarding-options dhcp-relay] 层次结构级别配置forward-snooped-clients语句。

    您可以为以下方案设置 forward-snooped-clients 选项:

    • 所有接口:将操作应用于所有接口。
    • 配置的接口:仅将操作应用于配置为接口组一部分的接口。
    • 未配置的接口:仅将操作应用于不属于接口组的接口。
  2. 要转发或丢弃侦听的数据包,请分别使用forward-snooped-clients选项配置allow-snooped-clientsno-allow-snooped-clients
    • 配置 allow-snooped-clients时,如果与有效订阅者关联了侦听的数据包,则会转发这些数据包。
    • 配置 no-allow-snooped-clients时,即使有有效的订阅者与之关联,被窥探的数据包也会被丢弃。

要详细了解设备基于 或 allow-snooped-clients no-allow-snooped-clientsforward-snooped-clients组合对 DHCP 侦听的数据包执行的操作,请参见 表 1表 2

表 1 显示了当您使用forward-snooped-clients选项进行配置allow-snooped-clients时,设备对 DHCP 中继代理窥探的数据包执行的操作。

表 1:启用侦听数据包转发时设备对侦听数据包执行的操作

配置适用于

对已配置接口的操作

对未配置接口的操作

所有接口

转发

转发

配置的接口

转发

下降

未配置的接口

侦听的 DHCP 数据包会在 DHCP 侦听数据库中创建订阅者条目。

转发

无配置

侦听的 DHCP 数据包会在 DHCP 侦听数据库中创建订阅者条目。

下降

表 2 显示了使用 配置forward-snooped-clients时设备对 DHCP 中继代理no-allow-snooped-clients窥探的数据包执行的操作。

表 2:禁用侦听数据包转发时设备对侦听数据包执行的操作

配置适用于

对已配置接口的操作

对未配置接口的操作

所有接口

下降 转发

配置的接口

下降 下降

未配置的接口

下降 转发

无配置

下降 下降

在 DHCP 中继代理侦听期间,设备依靠其全局配置来决定是转发还是丢弃 BOOTREPLY 数据包。此外,在续租期间,BOOTPREQUEST 数据包可能会直接单播到 DHCP 服务器,并且此数据包也会受到窥探。

表 3 显示了设备对侦 BOOTREPLY 听数据包执行的操作。

表 3:窥探BOOTREPLY者的操作包
配置状态 操作
forward-snooped-clients 未配置 如果未找到客户端,则被丢弃的窥探 BOOTREPLY 数据包
forward-snooped-clients 配置 如果未找到客户端,则转发的窥探 BOOTREPLY 数据包

在默认配置和使用 forward-snooped-clients 语句的配置中,设备都会将硬件控制平面上的所有 DHCP 流量转发到路由实例的路由平面,以拦截 DHCP 数据包。

您可以使用 no-snoop 选项禁用 DHCP 流量的窥探过滤器。

配置 no-snoop 选项时,DHCP 流量会流向硬件控制平面,但会绕过路由平面,从而避免在硬件控制平面上遭到拦截。

DHCP 侦听配置

使用以下配置选项启用或禁用全局、接口组或组中的特定接口的 DHCP 侦听。
  • 设置接口组
    创建支持 DHCP 侦听的命名接口组。此组必须包括具有通用 DHCP 或 DHCPv6 中继代理配置的接口。您必须指定接口名称才能将接口添加到组中。DHCP 中继代理在确定是转发还是丢弃流量时,会将这些接口视为已配置的接口。
    • 对于 DHCP 中继代理:

    • 对于 DHCPv6 中继代理:
  • 覆盖默认 DHCP 中继侦听
    您可以覆盖设备上的默认 DHCP 中继侦听配置,以显式启用或禁用侦听支持。指定 overrides 不带从属语句的语句将删除该层级的所有 DHCP 中继代理覆盖。您可以覆盖已命名接口组或具有指定接口组的特定接口的默认配置。
    在全局级别,分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理

    对于指定的接口组,请分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理
    对于组中的特定接口,请分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理

  • 启用侦听数据包的处理

    默认情况下,如果没有订阅者与数据包关联,路由器会丢弃被窥探的数据包。要覆盖默认 DHCP 配置并使中继代理能够转发来自窥探客户端的 DHCP 消息,必须显式配置该 allow-snooped-clients 语句。

    在全局级别上,分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理

    对于接口组,分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理

    对于组中的特定接口,请使用以下语句。
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理

  • 阻止来自窥探客户端的 DHCP 消息转发

    要覆盖默认 DHCP 配置并防止中继代理转发来自窥探客户端的消息,请使用以下命令。

    在全局级别上,分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理
    • 对于 DHCPv6 中继代理
    对于接口组,分别对 DHCP 中继代理和 DHCPv6 中继代理使用以下语句。
    • 对于 DHCP 中继代理
    • 对于 DHCPv6 中继代理
    对于组中的特定接口,请使用以下语句:
    • 对于 DHCP 中继代理

    • 对于 DHCPv6 中继代理

  • 正向侦听数据包
    为 DHCP 中继代理启用 DHCP 侦听数据包转发。您可以指定所有接口、所有已配置接口或非配置接口。

DHCP 侦听数据包转发的示例配置

  1. 为 DHCP 中继代理配置命名组,并向该组添加接口。DHCP 中继代理在确定是转发还是丢弃流量时,会将这些接口视为已配置的接口。
  2. 设置选项以覆盖组中继代理的默认配置。
  3. 为组启用 DHCP 侦听支持。
  4. 指定 DHCP 中继代理只能在配置的接口上转发侦听的数据包。在这种情况下,配置的接口在组client-group-1中。
  5. 禁用对组 client-group-2 中接口 ge-2/0/1.4 的 DHCP 侦听支持。
提示:

我们建议您阅读 DHCP 用户指南 ,并使用启用了 DHCP traceoptions 的实验室来检查和了解配置。