网络应用层之(1)DHCPv6协议

网络应用层之(1)DHCPv6协议


Author: Once Day Date: 2024年5月26日

一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦…

漫漫长路,有人对你微笑过嘛…

全系列文章可参考专栏: 通信网络技术_Once-Day的博客-CSDN博客。

参考文章:

  • 《TCP/IP详解卷一》
  • DHCPv6-原理浅谈+报文示例+简易配置(SLAAC+DHCPv6+PD前缀代理)–RFC8415_dhcpv6报文-CSDN博客
  • 一文读懂DHCP协议 && DHCPv6协议 - 知乎 (zhihu.com)
  • 奔涌的IPv6背后,DHCPv6协议你了解多少? - 知乎 (zhihu.com)
  • DHCPV6协议报文详解 - 华为 (huawei.com)
  • DHCPv6技术介绍-新华三集团-H3C
  • RFC 8415: Dynamic Host Configuration Protocol for IPv6 (DHCPv6) (rfc-editor.org)
  • Info-Finder(在线工具) 报文格式 (huawei.com)
  • DHCP - IP 报文格式大全 (huawei.com)
  • DHCPv6 - IP 报文格式大全 (huawei.com)

文章目录

  • 网络应用层之(1)DHCPv6协议
        • 1. 介绍
          • 1.1 DHCPv6协议介绍
          • 1.2 IPv6地址生命周期
          • 1.3 DHCPv6相关的RFC文档
        • 2. 报文格式
          • 2.1 DHCPv6报文格式
          • 2.2 DHCPv6中继报文格式
          • 2.3 DHCPv6报文类型
          • 2.4 DHCPv6身份关联(IA)
          • 2.5 DHCPv6唯一标识符(DUID)
          • 2.6 DHCPv6报文选项
        • 3. 工作流程
          • 3.1 DHCPv6基础交互流程
          • 3.2 DHCPv6网络组成和交互
          • 3.3 IPv6重复地址检测
        • 4. 总结

1. 介绍
1.1 DHCPv6协议介绍

DHCPv6(Dynamic Host Configuration Protocol for IPv6)是一种用于IPv6网络的自动配置协议,它允许IPv6主机自动获取IP地址、DNS服务器、域名等网络配置信息。DHCPv6协议是DHCP协议的IPv6版本,它建立在IPv6协议之上,提供了更多的功能和灵活性。

DHCPv6的发展历史:

  • 1998年,IETF(Internet Engineering Task Force)开始制定DHCPv6协议标准。
  • 2003年,DHCPv6的第一个版本RFC 3315发布,定义了DHCPv6的基本功能和消息格式。
  • 2007年,RFC 4649发布,引入了DHCPv6的无状态模式(Stateless DHCPv6),允许主机通过路由器通告获取配置信息。
  • 2010年,RFC 5970发布,定义了DHCPv6的选项和参数,扩展了DHCPv6的功能。
  • 2018年,RFC 8415发布,是DHCPv6协议的最新版本,合并了之前的RFC文档,并进行了一些优化和改进。

目前,DHCPv6已经得到广泛应用,尤其是在大型IPv6网络中,如企业网络、校园网等。DHCPv6为网络管理员提供了集中管理和配置IPv6主机的便利,简化了网络管理的复杂性。

DHCPv6的主要竞品是SLAAC(Stateless Address Autoconfiguration),SLAAC是IPv6协议内置的一种无状态地址自动配置机制,它允许IPv6主机根据路由器通告自动生成IPv6地址,而不需要DHCPv6服务器的参与

与DHCPv6相比,SLAAC具有以下特点:

  • 简单性,SLAAC不需要额外的服务器,配置过程更加简单。
  • 灵活性,SLAAC允许主机自行生成IPv6地址,不依赖于中心化的地址分配。
  • 扩展性,SLAAC可以更好地适应大规模的IPv6网络部署。

然而,SLAAC也有一些局限性,如无法提供其他网络配置信息(如DNS服务器),缺乏集中管理和控制等。因此,在实际应用中,DHCPv6和SLAAC经常结合使用,形成一种混合模式,称为"无状态DHCPv6"(Stateless DHCPv6)。在这种模式下,主机通过SLAAC获取IPv6地址,同时通过DHCPv6获取其他网络配置信息。

1.2 IPv6地址生命周期

在这里插入图片描述

IPv6主机的每个接口通常拥有多个地址,每个地址都拥有一组计时器,以指出相应地址可使用多长时间和目的作用。在IPv6中,地址分配包含一个首选生命周期和有效生命周期,满足上图所示的状态机。

  • 当一个地址第一次被使用时,进入一个临时或者乐观状态。
  • 处于临时状态的地址,仅能用于IPv6邻居发现协议,不可用于源和目的地址,并且一直进行重复地址检测(DAD),查看是否有其他节点使用该地址。
  • 乐观状态的地址可用于一组有限的用途(RFC 4429),直至DAD完成。
  • 处于首选状态时,可用于一般的用途(无限制使用)。
  • 当首选状态超时后,相应的首选地址将被废弃,此时可用于现有传输连接,但不能新建连接。
1.3 DHCPv6相关的RFC文档

以下是一些与DHCPv6相关的重要RFC文档:

  • RFC 3315 - Dynamic Host Configuration Protocol for IPv6 (DHCPv6),发布于2003年7月,定义了DHCPv6的基本协议、消息格式和选项,是DHCPv6协议的第一个正式标准,奠定了DHCPv6的基础。

  • RFC 3633 - IPv6 Prefix Options for Dynamic Host Configuration Protocol (DHCP) version 6,发布于2003年12月,定义了DHCPv6的前缀委派(Prefix Delegation)选项,允许DHCPv6服务器将IPv6前缀分配给客户端,用于创建子网。

  • RFC 3646 - DNS Configuration options for Dynamic Host Configuration Protocol for IPv6 (DHCPv6),发布于2003年12月,定义了DHCPv6的DNS配置选项,允许DHCPv6服务器为客户端提供DNS服务器地址和DNS搜索列表。

  • RFC 3898 - Network Information Service (NIS) Configuration Options for Dynamic Host Configuration Protocol for IPv6 (DHCPv6),发布于2004年10月,定义了DHCPv6的NIS配置选项,允许DHCPv6服务器为客户端提供NIS服务器地址和NIS域名。

  • RFC 4075 - Simple Network Time Protocol (SNTP) Configuration Option for DHCPv6,发布于2005年5月,定义了DHCPv6的SNTP配置选项,允许DHCPv6服务器为客户端提供SNTP服务器地址。

  • RFC 4242 - Information Refresh Time Option for Dynamic Host Configuration Protocol for IPv6 (DHCPv6),发布于2005年11月,定义了DHCPv6的信息刷新时间选项,允许DHCPv6服务器指定客户端刷新配置信息的时间间隔。

  • RFC 4649 - Dynamic Host Configuration Protocol for IPv6 (DHCPv6) Relay Agent Remote-ID Option,发布于2006年8月,定义了DHCPv6中继代理的Remote-ID选项,允许DHCPv6中继代理向DHCPv6服务器传递客户端的标识信息。

  • RFC 5970 - DHCPv6 Options for Network Boot,发布于2010年9月,定义了DHCPv6的网络引导选项,允许DHCPv6服务器为客户端提供网络引导所需的参数,如引导文件和引导服务器地址。

  • RFC 6221 - Lightweight DHCPv6 Relay Agent,发布于2011年5月,定义了轻量级DHCPv6中继代理(LDRA),简化了DHCPv6中继代理的实现,适用于资源受限的设备。

  • RFC 8415 - Dynamic Host Configuration Protocol for IPv6 (DHCPv6) bis,发布于2018年11月,是DHCPv6协议的最新版本,合并和更新了之前的DHCPv6 RFC文档,包括RFC 3315、RFC 3633、RFC 3646、RFC 3898、RFC 4075、RFC 4242和RFC 4649,修复了一些问题,并引入了新的特性和改进。

2. 报文格式
2.1 DHCPv6报文格式

DHCPv6协议使用UDP传输,客户端使用546端口,服务器使用547端口

DHCPv6报文格式由固定长度的字段和可变长度的选项字段组成,如下所示

在这里插入图片描述

各字段说明如下:

  • msg-type(1字节),表示DHCPv6报文的类型,如Solicit、Advertise、Request等。
  • transaction-id(3字节),用于标识一个DHCPv6事务,客户端生成一个唯一的事务ID,服务器在响应中使用相同的事务ID。
  • options(可变长度),包含DHCPv6的各种选项,如客户端标识符、服务器标识符、请求的参数等。选项的格式为TLV(Type-Length-Value)。
2.2 DHCPv6中继报文格式

DHCPv6中继代理用于转发DHCPv6报文,以支持客户端和服务器不在同一链路的情况。

DHCPv6中继报文在原有DHCPv6报文的基础上,添加了中继代理消息选项。

在这里插入图片描述

各字段说明如下:

  • msg-type(1字节),对于中继代理发送的报文,类型为Relay-Forward(12),对于中继代理接收的报文,类型为Relay-Reply(13)。
  • hop-count(1字节),记录报文经过的中继代理数量,每经过一个中继代理,该字段加1。
  • link-address(16字节),中继代理连接客户端的链路地址,通常是中继代理面向客户端的接口IPv6地址。
  • peer-address(16字节),客户端或下一跳中继代理的IPv6地址。
  • DHCPv6 Relay Message(可变长度), 必须包含名为"Relay Message option"的选项,当然,中继可以添加其他选项。
2.3 DHCPv6报文类型

以下是DHCPv6常见消息类型及其与DHCPv4消息的对应关系:

DHCPv6消(msg-type)DHCPv4消息作用
Solicit (1)DHCPDISCOVER客户端请求分配IPv6地址和配置参数
Advertise (2)DHCPOFFER服务器响应客户端的Solicit消息,提供可用的IPv6地址和配置参数
Request (3)DHCPREQUEST客户端请求从服务器获取IPv6地址和配置参数
Confirm (4)DHCPREQUEST客户端确认之前获取的IPv6地址和配置参数是否仍然有效
Renew (5)DHCPREQUEST客户端请求更新IPv6地址租约和配置参数
Rebind (6)DHCPREQUEST客户端在Renew失败后,请求任意服务器更新IPv6地址租约和配置参数
Reply (7)DHCPACK/DHCPNAK服务器响应客户端的Request、Confirm、Renew或Rebind消息
Release (8)DHCPRELEASE客户端释放分配的IPv6地址和配置参数
Decline (9)DHCPDECLINE客户端声明分配的IPv6地址已经被使用或无效
Reconfigure (10)FORCERENEW服务器通知客户端重新获取配置参数
Information-Request (11)DHCPINFORM客户端请求获取配置参数,但不请求分配IPv6地址
Relay-Forward (12)无对应消息中继代理将客户端的DHCPv6消息转发给服务器或下一跳中继代理
Relay-Reply (13)无对应消息服务器或中继代理将响应消息发送给上一跳中继代理,最终到达客户端

注意事项:

  • DHCPv6引入了一些新的消息类型,如Confirm、Reconfigure、Relay-Forward和Relay-Reply,这些消息在DHCPv4中没有对应的消息类型。
  • DHCPv6中的Renew和Rebind消息在功能上对应于DHCPv4中的DHCPREQUEST消息,但在DHCPv6中被细分为两种不同的消息类型。
  • DHCPv6中的Information-Request消息对应于DHCPv4中的DHCPINFORM消息,用于获取配置参数,但不分配IPv6地址。
  • 除了上述消息外,LEASEQUERY(租约查询)类消息并没有列出来。
2.4 DHCPv6身份关联(IA)

DHCPv6中引入了身份关联(Identity Association,IA)的概念,用于将一组相关的IPv6地址和配置参数关联起来,方便管理和续约。DHCPv6定义了三种类型的IA:

  • IA_NA(Identity Association for Non-temporary Addresses),用于为客户端分配一个或多个非临时IPv6地址

    • 每个IA_NA都有一个唯一的IAID(Identity Association Identifier),由客户端生成,用于标识该IA_NA。

    • IA_NA可以包含多个IPv6地址,每个地址都有自己的首选生存期(Preferred Lifetime)和有效生存期(Valid Lifetime)。

    • 客户端可以在一个DHCPv6请求中包含多个IA_NA,以获取多组IPv6地址。

  • IA_TA(Identity Association for Temporary Addresses),用于为客户端分配一个或多个临时IPv6地址

    • 临时地址通常用于保护隐私,定期更换,不用于长期稳定的通信。
    • 与IA_NA类似,每个IA_TA都有一个唯一的IAID,可以包含多个临时IPv6地址。
    • 客户端可以在一个DHCPv6请求中包含多个IA_TA,以获取多组临时IPv6地址。
  • IA_PD(Identity Association for Prefix Delegation),用于为客户端分配一个或多个IPv6前缀,客户端可以使用这些前缀创建子网并分配地址

    • IA_PD主要用于支持IPv6的前缀委派(Prefix Delegation),允许DHCPv6服务器将IPv6前缀分配给客户端,客户端再将这些前缀划分为子前缀,分配给下游设备。
    • 每个IA_PD都有一个唯一的IAID,可以包含多个IPv6前缀。
    • 客户端可以在一个DHCPv6请求中包含多个IA_PD,以获取多组IPv6前缀。

通过使用不同类型的IA,DHCPv6可以满足客户端对非临时地址、临时地址和前缀委派的不同需求。

2.5 DHCPv6唯一标识符(DUID)

DHCPv6引入了DUID(DHCP Unique Identifier)作为设备的唯一标识符,用于识别DHCPv6客户端和服务器。DUID在DHCPv6会话中保持不变,即使设备的接口硬件地址(如MAC地址)发生变化,DUID也不会改变。这提高了DHCPv6的稳定性和可靠性。

DUID由两部分组成:DUID类型(2字节)和标识符(可变长度)

 0                   1                   2                   30 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|               DUID-Type        |                             |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+                              |
.                                                              .
.                           Identifier                         .
.                                                              .
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

DHCPv6定义了三种主要的DUID类型:

  • DUID-LLT(Link-Layer address plus Time),DUID-Type为1。标识符包括硬件类型(16位)、时间(32位,自2000年1月1日以来的秒数)和链路层地址(如MAC地址),适用于具有稳定硬件地址的设备。

  • DUID-EN(Enterprise Number),DUID-Type为2。标识符包括IANA分配的企业号(32位)和企业特定的标识符(可变长度),适用于没有稳定硬件地址,但可以分配唯一标识符的设备。

  • DUID-LL(Link-Layer address),DUID-Type为3。标识符包括硬件类型(16位)和链路层地址,适用于具有稳定硬件地址,但无法获取时间信息的设备。

2.6 DHCPv6报文选项

以下是DHCPv6可用选项:

选项名称code描述和作用
CLIENTID1客户端标识符,用于标识DHCPv6客户端。通常基于客户端的DUID(DHCP Unique Identifier)构建。
SERVERID2服务器标识符,用于标识DHCPv6服务器。通常基于服务器的DUID构建。
IA_NA3Identity Association for Non-temporary Addresses,用于请求/分配非临时的IPv6地址。
IA_TA4Identity Association for Temporary Addresses,用于请求/分配临时的IPv6地址。
IAADDR5IA Address,与IA_NA或IA_TA选项一起使用,用于指定分配的IPv6地址及其相关参数。
如首选和有效生存期。
ORO6Option Request Option,客户端用于请求特定的DHCPv6选项。
PREFERENCE7服务器的优先级,数值越高表示优先级越高。
ELAPSED_TIME8客户端启动DHCPv6交互后经过的时间,以10毫秒为单位。
RELAY_MSG9中继代理转发的原始DHCPv6消息。
AUTH11认证选项,用于DHCPv6消息的完整性检查和身份验证。
UNICAST12服务器用于指示客户端将后续消息发送到特定的单播地址,而不是多播地址。
STATUS_CODE13表示DHCPv6操作的状态,如成功、未分配地址等。
RAPID_COMMIT14快速提交选项,客户端请求服务器使用两步握手快速分配地址,而不是标准的四步握手。
USER_CLASS15用户类别,客户端用于将自己标识为特定的用户类别,服务器可以基于此进行不同的处理。
VENDOR_CLASS16供应商类别,客户端用于标识设备的制造商或供应商,服务器可以基于此提供特定的配置。
VENDOR_OPTS17供应商特定选项,用于传递供应商定义的配置信息。
INTERFACE_ID18接口标识符,中继代理用于标识客户端消息的接收接口。
RECONF_MSG19重配置消息,服务器用于通知客户端有新的配置可用。
客户端应该发起Renew或Information-request交互以获取更新的配置。
RECONF_ACCEPT20重配置接受选项,客户端用于指示是否接受服务器的重配置消息。
DNS_RECURSIVE_NAME_SERVER23DNS递归名称服务器选项,用于向客户端提供一个或多个DNS递归解析服务器的IPv6地址。
DNS_DOMAIN_SEARCH_LIST24DNS域搜索列表选项,用于向客户端提供一个域名后缀列表,用于补充非完全限定域名(Non-FQDN)。
IA_PD25Identity Association for Prefix Delegation,前缀委派标识关联选项,用于请求/分配IPv6前缀。
IAPREFIX26IA Prefix,与IA_PD选项一起使用,用于指定委派的IPv6前缀及其相关参数,如首选和有效生存期。
RELAY_AGENT_REMOTE_ID37中继代理远程ID选项,用于标识连接到中继代理的客户端的远程设备。
通常包含远程设备的标识信息,如电路ID或订阅者ID。
RELAY_AGENT_SUBSCRIBER_ID38中继代理订阅者ID选项,用于标识连接到中继代理的客户端的订阅者。
通常包含订阅者的标识信息,如用户名或账号。
3. 工作流程
3.1 DHCPv6基础交互流程

在这里插入图片描述

DHCPv6协议的交互过程如下:

  • 客户机接入网络后,通过ICMPv6路由通告(RA)消息获知DHCPv6服务器的操作模式。假设RA消息中的M(可管理地址配置)和O(其他配置)标志都被置位,表示同时支持无状态和有状态地址配置模式。M关闭且O启用表示客户机使用无状态DHCPv6。

  • 客户机发送Solicit报文到FF02::1:2多播地址(所有DHCP中继和服务器),UDP目的端口547,源端口546。报文中包含客户机DUID、IA_NA(非临时地址请求)等选项。二层mac使用IPv6多播mac(33:33:00:01:00:02)

  • DHCP服务器收到Solicit后,回复Advertise单播报文给客户机。报文包含服务器的DUID、客户机的DUID、客户机IA_NA对应的IAAddress(分配的IPv6地址)等选项,表明可以为客户机提供IPv6地址。

  • 客户机收到一个或多个Advertise报文后,选择其中一个服务器,向其发送Request报文请求正式分配地址。报文目的地址、端口与Advertise相同,并包含请求分配的IA地址等信息。

  • 服务器收到Request报文后,正式分配地址,并回复Replay报文给客户机,确认地址分配。报文包含分配的IPv6地址、preferred和valid lifetime等。

  • 客户机收到Replay报文,提取分配的IPv6地址,并将地址配置到网卡上

  • 客户机启动DAD(Duplicate Address Detection)重复地址检测流程。向被分配的IPv6地址发送邻居请求(NS)报文,如果没有收到对应的邻居通告(NA)报文,说明地址没有冲突,可以正常使用。如果收到NA报文,则说明地址冲突,需要重新发起DHCP流程或手工指定新地址。

整个DHCPv6交互过程中,关键在于Solicit报文请求分配地址,Advertise/Replay报文回复确认可用地址,Request报文则是正式请求使用服务器Advertise的地址。

报文方面,Solicit和Request使用link-local地址作为源地址(也有可能是全零IP地址),发送到FF02::1:2多播地址。后续Advertise、Replay都是在Solicit报文建立的UDP单播连接上,使用Solicit的源地址和547端口作为目的地址和端口

下面是window DHCPv6获取地址的报文截图:

在这里插入图片描述

其中广播报文(Solicit)详细信息如下:

在这里插入图片描述

单播报文(Reply)详细信息如下:

在这里插入图片描述

3.2 DHCPv6网络组成和交互

本节内容源自华三IPv6技术介绍文档:DHCPv6技术介绍-新华三集团-H3C

典型的DHCPv6组网架构如下所示:

在这里插入图片描述

下面是各节点介绍:

  • DHCPv6客户端:动态获取IPv6地址、IPv6前缀或其他网络配置参数的设备。

  • DHCPv6服务器:负责为DHCPv6客户端分配IPv6地址、IPv6前缀和其他网络配置参数的设备。DHCPv6服务器不仅可以为DHCPv6客户端分配IPv6地址,还可以为其分配IPv6前缀。

    DHCPv6服务器为DHCPv6客户端分配IPv6前缀后,DHCPv6客户端向所在网络发送包含该前缀信息的RA消息,以便网络内的主机根据该前缀自动配置IPv6地址

  • DHCPv6中继:DHCPv6客户端通过本地链路范围的组播地址与DHCPv6服务器通信,以获取IPv6地址和其他网络配置参数。

如果服务器和客户端不在同一个链路范围内,则需要通过DHCPv6中继来转发报文,这样可以避免在每个链路范围内都部署DHCPv6服务器。

DHCPv6服务器为客户端分配地址/前缀的过程分为两类:交互两个消息的快速分配过程和交互四个消息的分配过程

(1) 交互四个消息的流程在3.1节中已经介绍,交互两个消息的快速分配过程如下:

在这里插入图片描述

  • DHCPv6客户端在发送的Solicit消息中携带Rapid Commit选项,标识客户端希望服务器能够快速为其分配地址/前缀和网络配置参数。
  • 如果DHCPv6服务器支持快速分配过程,则直接返回Reply消息,为客户端分配IPv6地址/前缀和其他网络配置参数。
  • 如果DHCPv6服务器不支持快速分配过程,则采用交互四个消息的分配过程为客户端分配IPv6地址/前缀和其他网络配置参数。

(2) 地址/前缀租约更新(renew单播报文)过程如下

在这里插入图片描述

  • DHCPv6服务器分配给客户端的IPv6地址/前缀具有一定的租借期限。在有效生命期到达之前,如果DHCPv6客户端希望继续使用该地址/前缀,则需要更新地址/前缀租约。
  • 地址/前缀租借时间到达时间T1(推荐值为首选生命期Preferred Lifetime的一半)时,DHCPv6客户端会向为它分配地址/前缀的DHCPv6服务器单播发送Renew报文,以进行地址/前缀租约的更新。
  • 如果客户端可以继续使用该地址/前缀,则DHCPv6服务器回应续约成功的Reply报文。
  • 如果该地址/前缀不可以再分配给该客户端,则DHCPv6服务器回应续约失败的Reply报文。

(3) 地址/前缀租约更新(rebind多播报文)过程如下:

在这里插入图片描述

  • 如果在T1时发送Renew请求更新租约,但是没有收到DHCPv6服务器的回应报文,则DHCPv6客户端会在T2(推荐值为首选生命期的0.8倍)时,向所有DHCPv6服务器组播发送Rebind报文请求更新租约
  • 如果客户端可以继续使用该地址/前缀,则DHCPv6服务器回应续约成功的Reply报文。
  • 如果该地址/前缀不可以再分配给该客户端,则DHCPv6服务器回应续约失败的Reply报文。
  • 如果DHCPv6客户端没有收到服务器的应答报文,则到达有效生命期后,客户端停止使用该地址/前缀。

(4) DHCPv6无状态配置过程如下

在这里插入图片描述

  • 地址无状态自动配置是指节点根据路由器发现/前缀发现所获取的信息,自动配置IPv6地址
  • 客户端以组播的方式向DHCPv6服务器发送Information-request报文,该报文中携带Option Request选项,指定客户端需要从服务器获取的配置参数。
  • 服务器收到Information-request报文后,为客户端分配网络配置参数,并单播发送Reply报文将网络配置参数返回给客户端。
  • 客户端检查Reply报文中提供的信息,如果与Information-request报文中请求的配置参数相符,则按照Reply报文中提供的参数进行网络配置。
  • 如果接收到多个Reply报文,客户端将选择最先收到的Reply报文,并根据该报文中提供的参数完成客户端无状态配置。

(5) DHCPv6中继工作过程

在这里插入图片描述

  • DHCPv6客户端向所有DHCPv6服务器和中继的组播地址FF02::1:2发送请求。
  • DHCPv6中继接收到请求后,将其封装在Relay-forward报文的中继消息选项(Relay Message Option)中,并将Relay-forward报文发送给DHCPv6服务器。
  • DHCPv6服务器从Relay-forward报文中解析出客户端的请求,为客户端选取IPv6地址和其他参数,构造应答消息,将应答消息封装在Relay-reply报文的中继消息选项中,并将Relay-reply报文发送给DHCPv6中继。
  • DHCPv6中继从Relay-reply报文中解析出服务器的应答,转发给DHCPv6客户端。
3.3 IPv6重复地址检测

IPv6地址重复检测(Duplicate Address Detection, DAD)是IPv6中的一个重要机制,用于确保在链路上分配或配置的IPv6地址是唯一的,不会与其他节点的地址冲突:

  • 地址分配,当一个IPv6节点通过无状态地址自动配置(SLAAC)、DHCPv6或手动配置获得一个IPv6地址时,该地址初始状态为"暂定(Tentative)"。

  • 发送邻居请求(NS),节点将其暂定地址作为目标地址,发送一个邻居请求(Neighbor Solicitation, NS)消息。

    这个NS消息的目的地址是被检测地址的请求节点多播地址,即FF02::1:FF00:0/104与被检测地址的最后24位相结合得到的地址。这个特殊的多播地址将NS消息传递给链路上可能使用同一地址的所有节点,NS消息的源地址字段使用未指定地址(:😃

  • 等待邻居通告(NA),发送NS消息后,节点进入DAD检测状态,等待一段时间(通常为1秒)。

    如果在此期间内没有收到对应的邻居通告(Neighbor Advertisement, NA)消息,则认为该地址没有冲突,可以安全使用。节点将地址状态标记为"首选(Preferred)",并开始正常使用该地址进行通信。

  • 处理地址冲突,如果节点在等待期间收到了一个或多个对应的NA消息,则表明该地址已经被其他节点使用,存在地址冲突。

    此时,节点不能使用这个地址,需要采取以下措施之一:

    • 如果地址是通过SLAAC或DHCPv6获得的,将停止使用该地址,并可能需要重新启动地址分配过程以获取新的地址。
    • 如果地址是手动配置的,节点将停止使用该地址,并需要管理员手动intervene以解决冲突。
  • 地址状态转换,一旦地址通过DAD检测并被标记为"首选",它将在其有效生存期内保持此状态。

    • 当地址的首选生存期到期后,其状态将转换为"弃用(Deprecated)",此时仍可以继续使用该地址进行现有通信,但不应再用于新的通信。
    • 当地址的有效生存期也到期后,其状态将转换为"无效(Invalid)",此时地址将被完全删除。不能再使用。

DAD利用IPv6的多播和邻居发现协议,在地址分配后自动执行检测过程,可以避免了地址冲突带来的通信问题。

4. 总结

DHCPv6协议目前主流路由器和网关设备都以支持,很多家庭网络都有分配IPv6地址,适当了解是非常有必要的。

相比于DHCPv4,报文格式和相关的字段简洁很多,但是在IPv6地址分配和IA、DUID、无状态配置和本地链路地址方面,会复杂许多,这是因为IPv6地址协议比IPv4实现要更加复杂,考虑了诸如隐私和网络自动化配置等因素。

随着时间发展,IPv4会慢慢向IPv6过滤,那些IPv6中晦涩难懂,十分罕见的概念,也许以后也会习以为常。







Alt

Once Day

也信美人终作土,不堪幽梦太匆匆......

如果这篇文章为您带来了帮助或启发,不妨点个赞👍和关注,再加上一个小小的收藏⭐!

(。◕‿◕。)感谢您的阅读与支持~~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/335649.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【使用ChatGPT构建应用程序】应用程序开发概述:1. 管理秘钥、2. 数据安全、3. 与应用程序解耦、4. 注意提示语的注入攻击

文章目录 一. 首先注意的两个方面1. 管理API密钥1.1. 用户提供API密钥1.2. 你自己提供API密钥 2. 数据安全和数据隐私 二. 软件架构设计原则:与应用程序解耦三. 注意LLM提示语的注入攻击1. 分析输入和输出2. 监控和审计3. 其他要注意的注入情况 在了解了ChatGPT的文…

easy-rule规则引擎使用

简介 轻量级的规则引擎&#xff0c;易于学习的api 简单来说&#xff0c;规则引擎就是一个函数&#xff1a;yf(x1,x2,…,xn) 将业务代码和业务规则分离&#xff0c;解耦业务决策和业务代码的绑定关系 入门示例 依赖引入 <dependency><groupId>org.jeasy</grou…

css卡片翻转 父元素翻转子元素不翻转效果

css卡片翻转 父元素翻转子元素不翻转效果 vue <div class"moduleBox"><div class"headTitle"><span class"headName">大额案例</span></div><div class"moduleItem"><span class"module…

数据结构 | 详解二叉树——堆与堆排序

&#x1f95d;堆 堆总是一棵完全二叉树。 大堆&#xff1a;父节点总是大于子节点。 小堆&#xff1a;父节点总是小于子节点。 注意&#xff1a;1.同一个节点下的两个子节点并无要求先后顺序。 2.堆可以是无序的。 &#x1f349;堆的实现 &#x1f334;深度剖析 1.父节点和子…

Gir clone 设置代理与错误

git查看、配置、删除代理 link git config --global https.proxy http://127.0.0.1:1080 git config --global http.proxyhttps://stackoverflow.com/questions/11265463/reset-git-proxy-to-default-configuration git config --global --unset http.proxy git config --gl…

Spring-注解

Spring 注解分类 Spring 注解驱动模型 Spring 元注解 Documented Retention() Target() // 可以继承相关的属性 Inherited Repeatable()Spirng 模式注解 ComponentScan 原理 ClassPathScanningCandidateComponentProvider#findCandidateComponents public Set<BeanDefin…

数据源不同?奥威BI软件是这么做的

面对数据源不同的情况&#xff0c;BI&#xff08;商业智能&#xff09;软件如奥威BI软件通常通过一系列技术和方法来实现数据的整理。以下以奥威BI软件为例&#xff0c;详细解释其如何整理不同数据源的数据&#xff1a; 数据收集&#xff1a; 爬虫技术&#xff1a;奥威BI软件…

Java程序设计

一 Java基础知识 1 Java语言概述 1.1 发展历史 1.2 Java应用领域 Web开发&#xff1a;电子商务网站、内部管理系统、社交网络、门户网站移动开发&#xff1a;Android开发桌面开发&#xff1a;办公软件、游戏、工具软件企业应用开发&#xff1a;客户关系管理、企业资源计划、…

【数据结构】探索树中的奇妙世界

专栏介绍&#xff1a; 哈喽大家好&#xff0c;我是野生的编程萌新&#xff0c;首先感谢大家的观看。数据结构的学习者大多有这样的想法&#xff1a;数据结构很重要&#xff0c;一定要学好&#xff0c;但数据结构比较抽象&#xff0c;有些算法理解起来很困难&#xff0c;学的很累…

redis 集群 底层原理以及实操

前言 上篇我们讲解了哨兵集群是怎么回事 也说了对应的leader选举raft算法 也说了对应的slave节点是怎么被leader提拔的 主要是比较优先级 比较同步偏移量 比较runid等等 今天我们再说说,其实哨兵也有很多缺点 虽然在master挂了之后能很快帮我们选举出新的master 但是对于单个ma…

C#解析JSON的常用库--Newtonsoft.Json

一、库介绍 在C#中&#xff0c;解析JSON的常用库有Newtonsoft.Json&#xff08;也称为Json.NET&#xff09;和 System.Text.Json&#xff08;从 .NET Core 3.0 开始引入&#xff09;。本文主要介绍 Newtonsoft.Json。 二、下载 官网&#xff1a; https://www.nuget.org/pack…

解决文件传输难题:如何绕过Gitee的100MB上传限制

引言 在版本控制和代码托管领域&#xff0c;Gitee作为一个流行的平台&#xff0c;为用户提供了便捷的服务。然而&#xff0c;其对单个文件大小设定的100MB限制有时会造成一些不便。 使用云存储服务 推荐理由&#xff1a; 便捷性&#xff1a;多数云存储服务如&#xff1a; Dro…

Vue——事件修饰符

文章目录 前言阻止默认事件 prevent阻止事件冒泡 stop 前言 在官方文档中对于事件修饰符有一个很好的说明&#xff0c;本篇文章主要记录验证测试的案例。 官方文档 事件修饰符 阻止默认事件 prevent 在js原生的语言中&#xff0c;可以根据标签本身的事件对象进行阻止默认事件…

隆道出席河南ClO社区十周年庆典,助推采购和供应链数字化发展

5月26日&#xff0c;“河南ClO社区十周年庆典”活动在郑州举办&#xff0c;北京隆道网络科技有限公司总裁助理姚锐出席本次活动&#xff0c;并发表主题演讲《数字化采购与供应链&#xff1a;隆道的探索与实践》&#xff0c;分享隆道公司在采购和供应链数字化转型方面的研究成果…

ZooKeeper安装

安装Zookeeper 1、下载Zookeeper安装包 打开链接选择一个版本进行下载 https://zookeeper.apache.org/releases.html2、上传Zookeeper安装包到集群 输入命令 scp apache-zookeeper-3.8.4-bin.tar.gz hadoop192.168.88.100:/tmp也可以使用xftp等上传&#xff0c;物理机用u盘…

方法的重写--5.29

当子类对父类的方法不满意时&#xff0c;可以进行重写&#xff0c;但是方法名字要与父类一样。 举例&#xff0c;我用people来举例&#xff0c;我是打工人&#xff0c;然后再创一个student类&#xff0c;重写方法我不是打工人&#xff0c;我是读书人。代码如下&#xff0c;发现…

如何让你的网站能通过域名访问

背景 当我们租一台云服务器&#xff0c;并在上面运行了一个Web服务&#xff0c;我们可以使用云服务器的公网IP地址进行访问&#xff0c;如下&#xff1a; 本文主要记录如何 实现让自己的网站可以通过域名访问。 买域名 可以登录腾讯云等主流公有云平台的&#xff0c;购买域名…

Matlab|基于PMU相量测量单元进行电力系统电压幅值和相角状态估计

主要内容 程序采用三种方法对14节点和30节点电力系统状态进行评估&#xff1a; ①PMU同步相量测量单元结合加权最小二乘法&#xff08;WLS&#xff09;分析电力系统的电压幅值和相角状态&#xff1b; ②并采用牛顿-拉夫逊方法进行系统潮流计算&#xff0c;结果作为理论分…

摩尔线程MTT S4000 AI GPU助力30亿参数大模型训练,性能比肩英伟达同类解决方案

中国国产GPU制造商摩尔线程(Moore Threads)在AI加速器领域取得了显著进展&#xff0c;其最新推出的MTT S4000 AI GPU在训练大规模语言模型时表现突出&#xff0c;据称相较于其前代产品有着显著的性能提升。根据cnBeta的报道&#xff0c;搭载S4000 GPU的全新“酷鹅千卡智能计算集…

技术面试,项目实战,求职利器

之前找工作一直想找一个能真正系统性学开发的地方&#xff0c;之前毕业找工作的时候无意间碰到下面这个网站&#xff0c;感觉还挺不错的&#xff0c;用上面的技术实战内容应对技术面试&#xff0c;也算是求职利器了。有需要的可以自取&#xff1a; https://how2j.cn?p156336 实…