【网络协议】----IPv6协议报文、地址分类

news2024/12/23 9:18:43

【网络协议】----IPv6协议简介

  • 【网络协议】----IPv6协议简介
    • IPv6特点
    • IPv4 和 IPv6报文结构
      • IPv6报文格式-拓展报头
    • IPv6地址分类
      • IPv6地址表示
      • IPv6单播地址
        • 可聚合全球单播地址
        • 链路本地地址
        • 唯一本地地址
        • 特殊地址
        • 补充 接口标识(主机位)生成方法
        • 通过EUI-64规范根据MAC地址生成接口ID
      • IPv6组播地址
        • 预定义组播地址
        • 被请求节点组播地址
        • IPv6组播的MAC地址映射

【网络协议】----IPv6协议简介

IPv6特点

=IPv6诞生背景=

  • 1、IPv4公网地址耗尽
  • 2、Internet用户快速增长
  • 3、NAT确实能解决私有地址空间与公网互访的问题,但是却破坏了端到端通信的完整性
  • 4、IPv4对移动性的支持不够理想等

IETF在20世纪90年代提出下一代互联网协议——IPv6,目前IPv6已成为公认IPv4未来的升级版本

IPv6技术特点

  • 地址空间巨大
  • 精简报文结构
  • 实现自动配置和重新编址
  • 支持层次化网络编址
  • 支持端对端安全
  • 更好的支持QOS、支持移动特性

IPv4 和 IPv6报文结构

IPv4报文结构
前面的文章有写过IPv4报文结构和各个字段作用,感兴趣的朋友可以看看
《数据帧、IP数据包、TCP、UDP报文格式详解》
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • Version:版本号,长度为4bit。对于IPv6,该值为6。
  • Traffic Class:流类别,长度为8bit。等同于IPv4中的Type Of Service字段,表示IPv6数据报的类或优先级,主要应用于QoS
  • Flow Label:流标签,长度为20bit。IPv6新增字段,用于区分实时流量。不同流标签加源地址可以唯一确定一条数据流,中间网络设备可以根据这些信息更加高效率的区分数据流。
  • Payload Length:有效载荷长度,长度为16bit。有效载荷是指紧跟IPv6报头的数据报的其它部分(即扩展报头和上层协议数据单元)
  • Next Header:下一个报头,长度为8bit。指明下一个扩展报头(如果存在)或上层协议的类型。
  • Hop Limit:跳数限制,长度为8bit。该字段类似于IPv4中的Time to Live字段,它定义了IP数据报所能经过的最大跳数。每经过一个路由器,该数值减去1,当该字段的值为0时,数据报将被丢弃。
  • Source Address:源地址,长度为128bit。表示发送方的地址。
  • Destination Address:目的地址,长度为128bit。表示接收方的地址。

IPv6报文格式-拓展报头

扩展报头是可选的,只有需要该扩展报头对应的功能时,数据的发送者才会添加相应扩展报头。
在这里插入图片描述

1、在IPv4中,IPv4报头包含可选字段Options,内容涉及security、Timestamp、Record route等,这些Options可以将IPv4报头长度从20字节扩充到60字节。在转发过程中,处理携带这些Options的IPv4报文会占用路由器很大的资源,因此实际中也很少使用

2、在IPv6中这些Option从基本报文格式中剥离,放到基本报头和上层协议数据单元之间一个IPv6报文可以包含0个、1个或多个扩展报头,仅当需要路由器或目的节点做某些特殊处理时,才由发送方添加一个或多个扩展头。与IPv4不同,IPv6扩展头长度任意,不受40字节限制,这样便于日后扩充新增选项,这一特征加上选项的处理方式使得IPv6选项能得以真正的利用。但是为了提高处理选项头和传输层协议的性能,扩展报头总是8字节长度的整数倍。

3、当使用多个扩展报头时,前面报头的Next Header字段指明下一个扩展报头的类型,这样就形成了链状的列表
extension header length

  1. 路由设备转发时根据基本报头中的Next Hesder值来决定是否要处理扩展头,并不是所有扩展报头都需要被路由转发设备查看和处理
  2. 除了目的选项扩展报头可能在一个IPv6报文中出现一次活两次(一次在路由扩展报头之前,另一次在上层协议数据报文之前),其余1扩展报头只能出现一次

IPv6地址分类

在这里插入图片描述

  1. IPv4地址分为:单播地址、组播地址、广播地址。而IPv6中没有广播地址,增加了任播地址,IPv6地址被分为:单播地址、组播地址、任播地址
  • 单播地址用于标识一个接口,发往该目的地址的报文会被送到被标识的接口,一个接口拥有多个IPv6地址是非常常见的现象
  • 组播地址用于标识多个接口,发往该目的地址到的报文会被送到被标识的所有接口
  • 任播地址用于标识多个(一组)网络接口(通常属于不同节点),发往该目的地址的报文会被送到被标识的所有接口中最近的一个接口上,实际上任播地址与单播地址使用同一个地址空间,就是说,由路由器决定数据包是做任播转发还是单播转发(任播地址只能作为目标地址)

IPv6地址表示

IPv6地址总长128比特,通常为8组,每组为4个十六进制数的形式,每组十六进制数间用冒号分隔,例FC00:0000:130F:0000:0000:09C0:876A:130B这是IPv6地址的首选格式
压缩:每组中的前导“0”都可以省略,所以上述地址可写为:FC00:0:130F::90C:876A:130B
地址中包含两个连续或多个连续均为“0”的组,可用冒号::来代替
注意:在一个IPv6地址中只能出现一次双冒号“::”

IPv6单播地址

可聚合全球单播地址

全球单播地址定义用于IPv6 Internet,是全局唯一和全局可达路由

类似于IPv4公网地址
由前缀、子网ID和接口标识组成
在这里插入图片描述

2 进制表示:0010 0000 0000 0000::
16 进制表示:2 0 0 0 ::
2 进制表示:0011 1111 1111 1111::
16 进制表示: 3 E E E ::

  • 全局路由前缀:由提供商指定给一个组织机构,一般至少为48bit。目前已分配的全局路由前缀前3bit均为001。前缀为2000::/3。
  • 子网:组织机构用子网ID来构建本地网络,与IPv4中的子网号作用类似。
  • 主机位,与IPv4中的主机ID作用相同
    在这里插入图片描述
链路本地地址

在一个节点启动ipv6协议栈时,节点每个接口会自动分配一个链路本地地址,专门用来和相同链路上的其它主机通信

  • 只能在连接到同一本地链路的节点之间使用,用于邻居发现,无状态地址,路由协议
  • 链路本地地址前缀FE80::/10,将接口ID添在后面作为地址的低64位
  • 每个IPv6接口都必须具备一个链路本地地址
    在这里插入图片描述
    ###
唯一本地地址
  • 因为IPv6要实现端到端的特性,导致此地址没有实施的可能性
  • 类似于IPv4中的私网地址,仅能在本地网络中使用,在公网Internet上不可被路由

唯一本地地址固定前缀FC00::/7。他被分为两块,其中FC00::/8暂未定义,另一块是FD00::/8,其格式如下:
在这里插入图片描述

特殊地址
  • 未指定地址。
    • 0:0:0:0:0:0:0:0/128 或者::/128。
      该地址作为某些报文的源地址,比如作为重复地址检测时发送的邻居请求报文(NS)的源地址,或者DHCPv6初始化过程中客户端所发送的请求报文的源地址。
  • 环回地址
    • 0:0:0:0:0:0:0:1/128 或者::1/128。
      与IPv4中的127.0.0.1作用相同,用于本地回环,发往::/1的数据包实际上就是发给本地,可用于本地协议栈回环测试。
  • IPv4兼容地址。
    • 在过渡技术中,为了让IPv4地址显得更加突出一些,定义了内嵌IPv4地址的IPv6地址格式。在这种表示方法中,IPv6地址的部分使用十六进制表示,IPv4地址部分可用十进制格式。如:64:FF9B::11.11.11.11 用于过渡技术NAT64 翻译。
      该地址已经几乎不再使用。
补充 接口标识(主机位)生成方法

关于接口ID:接口ID位64bit,用与标识链路上的接口,在每条链路上接口ID必须唯一

  • 接口ID可通过3种方法生成:手工配置、系统自动生成和IEEE EUI-64规范生成
通过EUI-64规范根据MAC地址生成接口ID

在这里插入图片描述

  • 假设一个接口的MAC地址如上图所示,那么采用EUI-64规范,接口可根据该MAC地址计算得到接口ID,由于MAC地址全局唯一,因此该接口ID也相应的具备全局唯一性。计算过程如下。
  • 将48bit的MAC地址对半劈开,然后插入“FFFE”,再对从左数起的第7位,也就是U/L位取反,即可得到对应的接口ID。
  • 而在在EUI-64接口ID中,第7bit的含义与MAC地址正好相反,0表示本地管理,1表示全球管理,所以使用EUI-64格式的接口ID,U/L位为1,则地址是全球唯一的,如果为0,则为本地唯一。这就是为什么要反转该位。
    在这里插入图片描述

IPv6组播地址

  • 用来表示一组接口。发往组播地址的数据将被转发给侦听该地址的多个设备
  • 地址范围:FF00::/8
预定义组播地址

Node-local
FF01::1,所有节点的组播地址。
FF01::2,所有路由器的组播地址。
Link-local
FF02::1,所有节点的组播地址。
FF02::2,所有路由器的组播地址。
FF02::1:FFXX:XXXX ,Solicited-Node组播地址。
FF02::5,所有OSPF路由器组播地址。
FF02::6,所有OSPF的DR路由器组播地址。
FF02:😄,所有PIM路由器组播地址。

被请求节点组播地址

被请求节点组播地址,通过节点的单播或任播地址生成。当一个节点具有单播或任播地址,就会对应生成一个被请求节点组播地址,并且加入这个组播组

  • 一个单播或任播地址对应一个被请求节点组播地址,用于地址解析和地址重复检测等功能
  • 被请求节点组播地址由固定前缀FF02::1:FF00:0/104和对对应IPv6地址最后24比特组成。被请求节点组播地址的有效范围为本地链路范围。

在这里插入图片描述
在这里插入图片描述

IPv6组播的MAC地址映射

以太网环境中,一个组播IPv6报文必须执行以太网封装

  • 组播IPv6报文的目的地址是组播IPv6地址,而目的MAC地址必须是组播MAC地址,并且必须与对应组播IPv6地址对应
  • 3333是专门为IPv6组播预留的MAC地址前缀组播MAC地址的后32bit从对应的组播IPv6地址的后32bit拷贝而来。
    例:
    在这里插入图片描述
    例如
    1、一个接口MAC地址为
    00E0-FC10-2E1B 48bit
    2、根据EUI-64生成接口ID 。第7bit取反,插入FFFE
    02E0:FCFF:FE10:2E1B
    3、 链路本地地址前缀FE80::/10 接口ID作为后64bit
    FE80::2E0:FCFF:FE10:2E1B
    4、对应链路本地地址的组播地址,固定前缀FF02::1:FF00:0/104加上对应IPv6地址收24bit
    FF02::1:FF10:2E1B
    5、对应组播地址的MAC地址,固定前缀3333-后32bit从对应组播IPv6地址后的32bit拷取
    3333-FF10-2E1B

接口MAC为 00E0-FC10-2E1B
组播MAC为 3333-FF10-2E1B
悟了!!!!
在这里插入图片描述

下一篇打算写下NDP协议

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Pytorch学习笔记——认识数据

最近在跟着小土堆pytorch的视频跟着学习python,根据自己的理解和课程上面的知识,写了这一篇学习笔记。 1、加载数据 数据的加载是学习pytorch的第一步,我们需要加载数据,完成特征工程,对加载数据存在的一些特…

智慧文旅开启沉浸式文化体验,科技让旅行更生动:借助智慧技术,打造沉浸式文化体验场景,让旅行者在旅行中深度感受文化的魅力

一、引言 随着科技的飞速发展,传统旅游行业正经历着前所未有的变革。智慧文旅,作为一种新兴的旅游模式,正以其独特的魅力,吸引着越来越多的旅行者。智慧文旅不仅改变了人们的旅行方式,更在深度上丰富了人们的文化体验…

09 - 数据清洗案例

流程图 kettle 面板图片 操作步骤 1、订阅数据源(kafka consumer) 2、抽取字段并转换key(JSON input) 3、判断img字段是否有值,有的话进行url转base64(JavaScript 代码) // 获取输入字段的值 v…

Windows内核开发:如何使用STL

前言 大家都知道应用层c的STL非常强大,非常好用,但是在内核下就没法用了。针对这个问题,经过我不懈的寻找,终于找到了解决内核无法使用STL的方法。 使用new/delete关键字 先说一下常用关键字如何在内核中使用。其实只需要在一个全…

C++类和对象详解(一)

目录 面向过程和面向对象初步认识类的引入类的定义类的两种定义方式声明和定义全部放在类体中 声名定义分离 类的作用域成员变量命名规则建议访问限定符 类的封装类的实例化类对象模型类的对象大小的计算扩展 结构体内存对齐规则 感谢各位大佬对我的支持,如果我的文章对你有用,…

Android Ant编译环境配置(Win)

1、 载ant包: 2、设置环境变量: 3、检查是否设置成功及版本 4、执行命令: android update project -p . -n “projectname”(例如:android update project --target 1 -p . -n “Couplet”)(只输入红色部分也是可以的…

GM EPUB Reader Pro for Mac:专业电子书阅读工具

GM EPUB Reader Pro是一款适用于Mac的专业EPUB阅读软件。它为用户提供了优质的阅读体验和丰富的功能。 GM EPUB Reader Pro支持EPUB格式,这是一种广泛使用的电子书格式,常用于小说、教育书籍、期刊等。您可以通过该软件打开和阅读EPUB文件,享…

使用js/java合并3dtiles

目录 前言: 需合并的json目录 aa/tileset.json bb/tileset.json cc/tileset.json dd/tileset.json ee/tileset.json js源码: 运行命令: 生成结果: java源码: Matrix.java ThreeDTilesJoin2.java pom文件…

微服务拆分

目录 前言: 逻辑视图架构风格 一、分层式架构风格 二、六边形架构 如何定义微服务架构 微服务的拆分 业务能力进行服务拆分 子域进行服务拆分 拆分的原则 单一职责 闭包原则 前言: 我们在软件开发的时候一直在谈论架构,那么什么是…

最全计算机毕业设计、大作业项目推荐(毕设源码+论文+PPT)

文章目录 1.毕设源码1.1 JAVA类源码模板1.2 PYTHON类源码模板1.3 C#类源码模板1.4 PHP类源码模板1.5 HTML类源码模板1.6 VUE类源码模板 2.毕设论文3.酷炫PPT 作者:xcLeigh 文章地址:https://blog.csdn.net/weixin_43151418/article/details/138598621 最…

短剧新纪元:引领潮流的短剧小程序开发,一触即达精彩世界

在信息爆炸的时代,短视频以其短小精悍、内容丰富的特点迅速崛起,成为人们日常生活中不可或缺的一部分。然而,短视频的短暂与碎片化,有时难以满足观众对完整故事的需求。为此,我们倾力打造了一款短剧小程序,…

某音扫码,短时间掉线问题,已解决

关于字节系抖音扫码掉线问题,已经困扰挺多人了,基本上你拿之前的逻辑去扫的话,估计几个小时或者一两天就掉线,这个问题呢,目前已经解决短时间掉线问题。抖音的cookie默认是大概60天左右的有效期

羊大师:羊奶营养守护孩子每一步

羊大师:羊奶营养守护孩子每一步 羊奶确实是一种营养丰富、具有多种健康益处的饮品,羊大师发现羊奶对于孩子的成长发育具有积极的促进作用。以下是一些关于羊奶对孩子成长的具体好处: 优质蛋白质:羊奶中的蛋白质含量高&#xff0c…

解决windows中的WSL Ubuntu子系统忘记root密码和用户密码问题

1、以管理员身份运行PowerShell 2、在powershell中执行wsl.exe --user root wsl.exe --user root如果出现了上面的报错,则需要运行步骤3、4,然后在执行步骤5改密码,如果没有出错,请直接跳到第5步改密码操作!&#xff…

【设计模式】之观察者模式

系列文章目录 【设计模式】之装饰器模式【设计模式】之工厂模式(三种)【设计模式】之工厂模式(三种) 前言 今天给大家介绍另一种设计模式--观察者模式,有了解webscoket实现原理的小伙伴应该对这个设计模式不陌生。不清…

2024年人工智能威胁态势报告:有关AI系统及AI应用的安全风险与安全防护全景

HiddenLayer公司最新发布的《2024年AI威胁场景报告》中,研究人员阐明了AI相关漏洞及其对组织的影响,并为应对这些挑战的IT安全和数据科学领导者提供了指导建议。最后,报告还揭示了各种形式的AI安全控制的前沿进展。 关键数据 平均而言&#x…

FMEA如何在设计活动中有效应用?——FMEA软件

免费试用FMEA软件-免费版-SunFMEA 在现代产品设计和开发过程中,FMEA(失效模式与影响分析)已经成为了一种不可或缺的工具。它的核心目标是在产品或过程设计的早期阶段,通过识别和分析潜在的失效模式,预防和控制可能出现…

react路由的简单demo

1.结构 2.router的index.js代码 import Home from "../pages/home/index";const routes [{path: "/",element: <Home />,},{path: "home",element: <Home />,}, ];export default routes;3.app.js代码 import "./App.css&qu…

Android 开机启动扫描SD卡apk流程源码分析

在开机的时候&#xff0c;装在SD卡的apk和装在系统盘的apk扫描过程不一样&#xff0c;系统盘apk在系统启动过程中扫描&#xff0c;而SD卡上的就不是&#xff0c;等系统启动好了才挂载、扫描&#xff0c;下面就说下SD扫描的流程&#xff1a; 在SystemServer启动MountService&am…

概念解析 | 威胁建模与DREAD评估:构建安全的系统防线

注1:本文系"概念解析"系列之一,致力于简洁清晰地解释、辨析复杂而专业的概念。本次辨析的概念是:威胁建模和DREAD模型 概念解析 | 威胁建模与DREAD评估:构建安全的系统防线 What Is Threat Modeling? Definition, Process, Examples, and Best Practices - Spic…