文章目录
- 一、IPV6
- 二、 二层交换
- 三、STP 生成树协议
- 六、路由
- 七、RIP
- 八、OSPF
- 九、NAT 网络地址转换技术
一、IPV6
1. IPv6的基本概念
1.1 IPv6地址
1.2 IPv6基本报头
IPv6的基本报头在IPv4报头的基础上,增加了流标签域,去除了一些冗余字段,使报文头的处理更为简单、高效。
IPv6报文由IPv6基本报头、IPv6扩展报头以及上层协议数据单元三部分组成。
基本报头中的各字段解释如下:
- Version:版本号,长度为4bit。对于IPv6,该值为6。
- Traffic Class:流类别,长度为8bit,它等同于IPv4报头中的TOS字段,表示IPv6数据报文的类或优先级,主要应用于QoS。
- Flow Label:流标签,长度为20bit,它用于区分实时流量。流可以理解为特定应用或进程的来自某一源地址发往一个或多个目的地址的连续单播、组播或任播报文。IPv6中的流标签字段、源地址字段和目的地址字段一起为特定数据流指定了网络中的转发路径。这样,报文在IP网络中传输时会保持原有的顺序,提高了处理效率。随着三网合一的发展趋势,IP网络不仅要求能够传输传统的数据报文,还需要能够传输语音、视频等报文。这种情况下,流标签字段的作用就显得更加重要。
- Payload Length:有效载荷长度,长度为16bit,它是指紧跟IPv6报头的数据报文的其它部分。
- Next Header:下一个报头,长度为8bit。该字段定义了紧跟在IPv6报头后面的第一个扩展报头(如果存在)的类型。
- 跳数限制(Hop Limit),长度为8bit,该字段类似于IPv4报头中的Time to Live字段,它定义了IP数据报文所能经过的最大跳数。每经过一个路由器,该数值减去1;当该字段的值为0时,数据报文将被丢弃。
- Source Address:源地址,长度为128bit,表示发送方的地址。
- Destination Address:目的地址,长度为128bit,表示接收方的地址。
与IPv4相比,IPv6报头去除了IHL、Identifier、Flags、Fragment Offset、Header Checksum、 - Options、Padding域,只增了流标签域,因此IPv6报文头的处理较IPv4大大简化,提高了处理效率。另外,IPv6为了更好支持各种选项处理,提出了扩展头的概念。
1.3 IPv6扩展报头
IPv6扩展报头是跟在IPv6基本报头后面的可选报头,可以有一个或多个。
IPv6增加了扩展报头,使得IPv6报头更加简化。一个IPv6报文可以包含0个、1个或多个扩展报头,仅当需要路由器或目的节点做某些特殊处理时,才由发送方添加一个或多个扩展头。IPv6支持多个扩展报头,各扩展报头中都含有一个下一个报头字段,用于指明下一个扩展报头的类型。这些报头必须按照以下顺序出现:
- IPv6基本报头
- 逐跳选项扩展报头
- 目的选项扩展报头
- 路由扩展报头
- 分片扩展报头
- 认证扩展报头
- 封装安全有效载荷扩展报头
- 目的选项扩展报头(指那些将被分组报文的最终目的地处理的选项)
- 上层协议数据报文
除了目的选项扩展报头外,每个扩展报头在一个报文中最多只能出现一次。目的选项扩展报头在一个报文中最多也只能出现两次,一次是在路由扩展报头之前,另一次是在上层协议扩展报头之前。
2. IPv6地址格式和地址类型
2.1 IPv6地址格式
IPv6地址长度为128比特,每16比特划分为一段,每段由4个十六进制数表示,并用冒号隔开。
IPv6地址包括网络前缀和接口标识两部分。
2. 2 IPv6地址压缩格式
每一组中的前导“0”都可以省略。
地址中包含的连续全为0的组,可以用双冒号“::”来代替。
注意:如果一个IPV6地址中只能出现一个‘::’,否则会出现歧义
2.3 IPv6地址分类
IPv6地址分为单播地址、任播地址、组播地址三种类型。
单播地址的格式是2000::/3
,代表公共IP网络上任意可及的地址。IANA负责将该段地址范围内的地址分配给多个区域互联网注册管理机构(RIR)。RIR负责全球5个区域的地址分配。以下几个地址范围已经分配:2400::/12 (APNIC)、2600::/12 (ARIN)、2800::/12 (LACNIC)、2A00::/12 (RIPE NCC)和2C00::/12 (AfriNIC),它们使用单一地址前缀标识特定区域中的所有地址。2000::/3地址范围中还为文档示例预留了地址空间,例如2001:0DB8::/32。
链路本地地址只能在连接到同一本地链路的节点之间使用。可以在自动地址分配
、邻居发现和链路上没有路由器的情况下使用链路本地地址。以链路本地地址为源地址或目的地址的IPv6报文不会被路由器转发到其他链路。链路本地地址的前缀是FE80::/10
。
组播地址的前缀是FF00::/8
。组播地址范围内的大部分地址都是为特定组播组保留的。跟IPv4一样,IPv6组播地址还支持路由协议。IPv6中没有广播地址。组播地址替代广播地址可以确保报文只发送给特定的组播组而不是IPv6网络中的任意终端。
IPv6还包括一些特殊地址,比如未指定地址::/128。如果没有给一个接口分配IP地址,该接口的地址则为::/128
。需要注意的是,不能将未指定地址跟默认IP地址::/0
相混淆。默认IP地址::/0跟IPv4中的默认地址0.0.0.0/0类似。环回地址127.0.0.1在IPv6中被定义为保留地址::1/128
。
2.4 IPv6单播地址
全球单播地址带有固定前缀,类似于IPv4中的公网地址
链路本地单播地址前缀为FE80::/10。
单播地址主要包含全球单播地址和链路本地地址。全球单播地址(例如2000::/3)带有固定的地址前缀,即前三位为固定值001。其地址结构是一个三层结构,依次为全球
路由前缀、子网标识和接口标识
。全球路由前缀由RIR和互联网服务供应商(ISP)组成,RIR为ISP分配IP地址前缀。子网标识定义了网络的管理子网。
2.5 IPv6组播地址
所有IPv6组播地址都以FF开始。
IPv6为需要使用组播发送数据的协议预留了一些组播组。
1. IPv6的组播与IPv4相同,用来标识一组接口,一般这些接口属于不同的节点。一个节点可能属于0到多个组播组。
2. 目的地址为组播地址的报文会被该组播地址标识的所有接口接收。
3. 一个IPv6组播地址是由前缀、标志(Flag)字段、范围(Scope)字段以及组播组ID(Group ID)4个部分组成:
- 前缀:IPv6组播地址的
前缀是FF00::/8(1111 1111)
。 - 标志字段(Flag):长度4bit,目前只使用了最后一个比特(前三位必须置0),当该位值为0时,表示当前的组播地址是由IANA所分配的一个
永久分配地址
;当该值为1时,表示当前的组播地址是一个临时组播地址(非永久分配地址)
。 - 范围字段(Scope):长度4bit,用来限制组播数据流在网络中发送的范围。
- 组播组ID(Group ID):长度112bit,用以标识组播组。目前,RFC2373并没有将所有的112位都定义成组标识,而是建议仅使用该112位的最低32位作为组播组ID,将剩余的80位都置0,这样,每个组播组ID都可以映射到一个唯一的以太网组播MAC地址(RFC2464)。
2.6 IPv6任播地址
**任播地址标识一组网络接口(通常属于不同的节点)。`目标地址`是任播地址的数据包将发送给其中路由意义上最近的一个网络接口**。任播过程涉及一个任播报文发起方和一个或多个响应方。任播报文的发起方通常为请求某一服务(DNS查找)的主机或请求返还特定数据(例如,HTTP网页信息)的主机。**任播地址与单播地址在格式上无任何差异,唯一的区别是一台设备可以给多台具有相同地址的设备发送报文。**企业网络中运用任播地址有很多优势。其中一个优势是业务冗余。比如,用户可以通过多台使用相同地址的服务器获取同一个服务(例如,HTTP)。这些服务器都是任播报文的响应方。如果不是采用任播地址通信,当其中一台服务器发生故障时,用户需要获取另一台服务器的地址才能重新建立通信。如果采用的是任播地址,当一台服务器发生故障时,任播报文的发起方能够自动与使用相同地址的另一台服务器通信,从而实现业务冗余。
使用多服务器接入还能够提高工作效率。例如,用户(即任播地址的发起方)浏览公司网页时,与相同的单播地址建立一条连接,连接的对端是具有相同任播地址的多个服务器。用户可以从不同的镜像服务器分别下载html文件和图片。用户利用多个服务器的带宽同时下载网页文件,其效率远远高于使用单播地址进行下载。(分布式
)
3. IPv6无状态地址配置的过程
3.1 IPv6无状态地址自动配置
网络节点向相连的路由器发送RS,请求地址前缀信息。
路由器通过发送路由器通告RA,回复地址前缀信息。
IPv6支持无状态地址自动配置,无需使用诸如DHCP之类的辅助协议,主机即可获取IPv6前缀并自动生成接口ID。路由器发现功能是IPv6地址自动配置功能的基础,主要通过以下两种报文实现:
RA报文:每台路由器为了让二层网络上的主机和其它路由器知道自己的存在,定期以组播方式(FF02::1 所有主机)发送携带网络配置参数的RA报文。RA报文的Type字段值为134
。
RS报文:主机接入网络后可以主动发送RS报文。RA报文是由路由器定期发送的,但是如果主机希望能够尽快收到RA报文,它可以立刻主动发送RS报文给路由器。网络上的路由器收到该RS报文后会立即向相应的主机单播回应
RA报文,告知主机该网段的默认路由器和相关配置参数。RS报文的Type字段值为133
。
3.2 EUI-64规范
将FFFE插入MAC地址的前24位与后24位之间,并将第7位的值取反(比如0改为1)即可生成接口ID。
为了通过IPv6网络进行通信,各接口必须获取有效的IPv6地址,以下三种方式可以用来配置IPv6地址的接口ID:
- 网络管理员手动配置;
- 通过系统软件生成;
- 采用扩展唯一标识符(EUI-64)格式生成。
就实用性而言,EUI-64格式是IPv6生成接口ID的最常用方式。
IEEE EUI-64标准采用接口的MAC地址生成IPv6接口ID。MAC地址只有48位,而接口ID却要求64位。MAC地址的前24位代表厂商ID,后24位代表制造商分配的唯一扩展标识。
MAC地址的第七高位是一个U/L位,值为0时表示MAC地址全局唯一,值为1时表示MAC地址本地唯一。
在MAC地址向EUI-64格式的转换过程中,在MAC地址的前24位和后24位之间插入了16比特的FFFE
,并将U/L位的值从0变成了1
,这样就生成了一个64比特的接口ID,且接口ID的值全局唯一。接口ID和接口前缀一起组成接口地址。
3.3 IPv6无状态地址DAD检查
当为接口配置IPv6地址时,DAD用来在本地链路范围内检测将要使用的IPv6地址是否唯一
。
设备在给接口分配IPv6单播地址之前会进行重复地址检测(DAD),确认是否有其它的节点使用了该地址。尤其是在地址自动配置的时候,进行DAD检测是很必要的。一个IPv6单播地址在分配给一个接口之后且通过重复地址检测之前称为试验地址,
此时该接口不能使用这个试验地址进行单播通信,但是仍然会加入两个组播组:ALL-nodes组播组和Solicited-node组播组。Solicited-node组播组
由单播或任播地址的后24位加上地址前缀FF02:0:0:0:0:1:FF00::/104组成。
例如,本示例中配置的试验地址为2000::1,该地址被加入Solicited-node组播组FF02::1:FF00:1。
IPv6重复地址检测技术和IPv4中的免费ARP类似
:用于地址分配或主机连接网络时检测重复的IPv4主机地址。
节点向一个自己将使用的试验地址所在的Solicited-node组播组发送一个以该试验地址为请求的目标地址的邻居请求**(NS)报文
,如果收到某个其它站点回应的邻居通告(NA)报文
,就证明该地址已被网络上使用,节点将不能使用该试验地址进行通信。这种情况下,网络管理员需要手动为该节点分配另外一个地址。(回复NA报文是告诉发送NS报文的主机,该节点已经被使用)**
4. IPv6过渡技术
4.1 双协议栈技术
同时启用v4与v6协议栈
双栈技术
- 同时支持IPv6和IPv4协议
- 应用程序根据DNS解析地址类型选择使用IPv6或IPv4协议
优点
互通性好,实现简单,允许应用逐渐从IPv4过渡到IPv6
缺点
- 只适用双栈节点本身
- 对每个IPv4节点都要升级,成本较大,没有解决IPv4地址紧缺问题
4.2 隧道技术
v6报文封装在v4中(主流技术)
4.2.1 GRE隧道技术
IPv6报文被包含在GRE报文中作为GRE的载荷
优点
- 通用性好
- 技术成熟,易于理解
缺点
维护复杂
GRE隧道流程
- 发送方与接收方
都是双栈设备
- 隧道已预先建立好
- 发送方封装报文,接收方解封装
4.2.2 IPv6 in IPv4隧道技术
IPv6报文被包含在IPv4报文中作为IPv4的载荷(没有GRE的封装)
同GRE隧道有类似的优缺点
6to4隧道流程
- 同自动隧道技术类似6to4中继
- 通往纯IPv6网络的网关
4.2.3 ISATAP隧道技术
连接IPv4网点内部的IPv6主机和路由器
将IPv4网点作为一个NBMA链路,在IPv4报文中封装IPv6报文
优点
IPv4网点内部的IPv6主机可自动获得IPv6前缀
缺点
IPv6地址为固定格式
4.3 网络地址转换
NAT-PT
NAT-PT原理
- 通过中间的
NAT-PT协议转换服务器
,实现纯IPv6节点和纯IPv4节点间的互通- NAT-PT服务器分配动态IPv4地址来标识IPv6主机(与DNS配合)
- NAT-PT服务器向相邻IPv6网络宣告96位地址前缀信息,用于标识IPv4主机
- NAT-PT服务器负责IPv4-to-IPv6,或IPv6-to-IPv4的报文转换
优点
只需设置NAT-PT服务器
缺点
资源消耗较大,服务器负载重
NAT-PT种类
静态NAT-PT
- NAT-PT服务器提供
一对一的IPv6地址和IPv4地址的映射
。- 配置复杂,使用大量的IPv4地址。
动态NAT-PT
- NAT-PT服务器提供
多对一的IPv6地址和IPv4地址的映射
。- 采用上层协议复用的方法。
NAT-PT DNS ALG
- 动态NAT-PT与DNS ALG联合使用,转换DNS请求。
- 可利用原有的DNS服务器。
4.3.1 静态NAT-PT转换过程
4.3.2 动态NAT-PT转换过程
4.3.3 NAT-PT DNS ALG转换过程
5. 常见问题
IPv6主机无状态地址自动配置的过程是什么?
IPv6主机首先通过路由器发现功能来获取地址前缀信息,之后通过向接口已有的48比特MAC地址中插入16比特的FFEE生成接口ID,在生成了IPv6地址后会通过重复地址检测来确认地址是否唯一。(DAD检查)
二、 二层交换
分享今日:
引入博客:
二层交换技术
二层交换特点
二层交换(二层通信):交换帧,源和目的MAC地址不会变,但是涉及到路由器(或者具有三层转发功能的交换机)源MAC地址会改变。
**广播域:**接收同样广播消息的节点的集合;
**冲突域:**连接在同一条线上所有工作站的集合;
区别:
- 广播域可以划分网段,冲突域一般在同一个网段;
- 广播域基于二层,冲突域基于一层;
- 一个局域网就是一个广播域;
- 集线器(hub)所有端口位于同一个广播域,冲突域;
- 二层交换机(switch)所有端口在一个广播域,每一个端口是一个冲突域;
1. 二层交换基础
1.1 园区网三层结构
-
核心层(CO):高速转发、服务器接入、
路由选择
-
汇聚层(GS):流量汇聚、链路冗余、设备冗余、路由选择
-
接入层(AS):用户接入、接入安全、访问控制
1.2 二层交换机主要功能
- 泛洪:把一个帧从除了进入端口外的所有端口转发出去;
- 转发:从某一端口转发到另一端口;
- 丢弃:不进行转发,直接丢弃;
1.3 交换机转发原理
1.3.1 单播转发
- 收到一个单播帧,交换机
会在Mac地址表中查找这个帧的目的Mac地址
,找不到直接泛洪; - 若找到,先与入接口进行比较;如果与入接口相同,丢弃,如果不同,转发。
1.3.2 广播转发
不会查找Mac地址,直接转发。
1.3.3 组播转发
1.4 PC与交换机收到单播与广播帧
1.4.1 PC 收到
- **单播帧:**将单播帧的目的MAC地址
与自己网卡MAC地址进行比较
,如果与本地网卡MAC地址一致,则根据单播帧的类型字段的值将数据载荷上传到网络层的相应处理模块,如果不一致直接丢弃。(先与本地MAC比较再上送) - 广播帧:直接根据该广播帧的类型字段类型直接上送至网络层的相应模块处理。(直接上送)
1.4.2 交换机收到
- 单播帧:不会与本地比较MAC地址,而是直接去查Mac地址表
- 广播帧:直接泛洪。
2. VLAN
2.1 VLAN作用
- 将交换机的端口划分进特定的VLAN(不同的广播域);
- 通常把划分前的,规模较大的广播域称为LAN,吧划分后,规模较小的广播域称为VLAN。
2.2 802.1Q帧格式
-
IEEE 802.1D定义了不支持VLAN特性交换机的标准规范,IEEE 802.1Q定义了关于支持VLAN特性的交换机标准;
-
通过tag区分不同VLAN;
标签 | 含义 |
---|---|
TPID | Tag Protocol ID,表示这个帧是否有tag,0x8100表示带有Tag(固定值) |
PRI | Priority,帧优先级,越大越优先 |
CFI | Canoncial Format Indicator |
VID | VLAN Identification,表示该帧所属VLAN |
2.3 链路类型
VLAN链路分为两种类型:Access链路
和Trunk链路
。
接入链路(Access Link):连接用户主机和交换机的链路称为接入链路;在一条Access链路上运动的帧**只能是Untagged 帧
。
干道链路(Trunk Link):连接交换机和交换机、交换机与路由器的链路称为干道链路,在一条trunk链路上运动的帧只能是tagged 帧
**。
2.4 PVID
PVID即Port VLAN ID,代表端口的缺省VLAN
。交换机从对端设备收到的帧有可能是Untagged的数据帧,但所有以太网帧在交换机中都是以Tagged的形式来被处理和转发的,因此交换机必须给端口收到的Untagged数据帧添加上Tag。为了实现此目的,必须为交换机配置端口的缺省VLAN。当该端口收到Untagged数据帧时,交换机将给它加上该缺省VLAN的VLAN Tag。
2.5 端口类型☆☆☆
2.5.1 Access 端口
收到帧:Access端口在收到数据后会添加VLAN Tag,VLAN ID和端口的PVID相同
。
发出帧:Access端口在转发数据前会移除VLAN Tag
。
Access端口收发数据帧的规则如下:
- 如果该端口收到对端设备发送的帧是untagged(不带VLAN标签),交换机将强制加上该端口的PVID。(因为因特网上交换机中所有帧都带有Tag,所以加上默认tag)
- 如果该端口收到对端设备发送的帧是tagged(带VLAN标签),交换机会检查该标签内的VLAN ID。
当VLAN ID与该端口的PVID相同时,接收该报文
。当VLAN ID与该端口的PVID不同时,丢弃该报文
。 - Access端口发送数据帧时,总是先剥离帧的Tag,然后再发送。Access端口发往对端设备的以太网帧永远是不带标签的帧。(Access接口与PC相连接,PC不会接受有Tag标记的帧,直接丢弃)
2.5.2 Trunk 端口
- 当一条链路,需要承载多VLAN信息的时候,需使用trunk来实现;
- Trunk两端的交换机需采用相同的干道协议;
- 一般见于交换机之间或交换机与路由器之间;
在本示例中,SWA和SWB连接主机的端口为Access端口,PVID如图所示。SWA和SWB互连的端口为Trunk端口,PVID都为1,此Trunk链路允许所有VLAN的流量通过。当SWA转发VLAN1的数据帧时会剥离VLAN标签,然后发送到Trunk链路上。而在转发VLAN20的数据帧时,不剥离VLAN标签直接转发到Trunk链路上。
每一个Trunk 除了需要配置PVID之外还需要配置,允许通过VLAN ID的列表。
Trunk端口收发数据帧的规则如下:
- 当接收到对端设备发送的不带Tag的数据帧时,会添加该端口的PVID,如果PVID在允许通过的VLAN ID列表中,则接收该报文,否则丢弃该报文。
- 当接收到对端设备发送的带Tag的数据帧时,检查VLAN ID是否在允许通过的VLAN ID列表中。如果VLAN ID在接口允许通过的VLAN ID列表中,则接收该报文。否则丢弃该报文。
- 端口发送数据帧时,当VLAN ID与端口的PVID相同,且是该端口允许通过的VLAN ID时,去掉Tag,发送该报文。当VLAN ID与端口的PVID不同,且是该端口允许通过的VLAN ID时,保持原有Tag,发送该报文。(
PVID 与 VLAN ID相同去掉Tag,不同保持原有Tag
)
2.6 VLAN 的类型(划分方法)
2.6.1 基于端口的VLAN(Port-based VLAN)
基于端口的VLAN通常也被称为物理层VLAN或一层VLAN
。
划分原则: 将VLAN编号(VLAN ID)映射到物理端口上,从某一个端口进入交换机的、由终端计算机发送的Untagged 帧都被划分到该端口的VLAN ID 所表明的那个VLAN。(物理端口与VLAN ID的映射
)
2.6.2 基于Mac地址的VLAN(MAC-based vlan )
基于Mac地址的VLAN也被称为二层VLAN
。
**划分原则:**交换机内部维护了一个MAC地址与VLAN ID的对应表,当交换机接收到计算机的Unragged帧时,交换机分析帧中的源Mac地址,然后查询对应表,并根据对应关系把这个帧划分到相应的VLAN中。(MAC地址与VLAN ID的映射
)
2.6.3 基于协议的VLAN(Protoclo-based VLAN)
基于协议的VLAN也被称为三层VLAN
。
划分原则:交换机根据发送的 Untagged 帧的类型字段来决定帧的VLAN归属。(协议类型与VLAN ID映射
)
例如:ipv4划分一个VLAN,ipv6划分一个VLAN。
2.7 VLAN 的范围
VLAN ID | 范围 | 用途 | 是否通过VTP传播 |
---|---|---|---|
0和4095 | 保留 | 用户不能使用 | 不适用 |
1 | 常规范围 | 默认VLAN,不可删除 | 是 |
2-1000 | 常规范围 | 用户能够创建、使用和删除 | 是 |
1001 | 常规范围 | 用户不能创建、使用和删除 | 是 |
1002-1005 | 保留 | FDDI和令牌环 | 不适用 |
1006-1009 | 保留 | 不适用 | |
1010-1024 | 保留 | 不适用 | |
1025-4094 | 保留 | 有限使用 | 否 |
2.8 VLAN成员模式
2.8.1 静态 VLAN
- 交换机上的端口以
手动方式
分配给VLAN;
2.8.2 动态 VLAN
- 使用
VMPS
可以根据连接到交换机端口的设备的源 MAC 地址,动态地将端口分配给 VLAN; - 华为使用
GVRP
3. VTP(VLAN Trunking Protocol)
- 一个能够宣告VLAN配置信息的信息系统;
- 通过一个共有的管理域,维持VLAN配置信息的一致性;
- VTP只能在trunk端口发送要宣告的信息;
- 支持混合的介质主干连接(快速以太网, FDDI, ATM).
3.1 VTP 模式
Server 模式 | Client | Transparent |
---|---|---|
创建vlan | 发送/转发信息宣告 | 创建VLAN |
修改vlan删除vlan | 同步 | 删除VLAN |
发送/转发信息宣告 | VLAN信息不会存贮于NVRAM | 删除VLAN |
同步 | 转发信息宣告 | |
VLAN信息存储于NVRAM | 不同步 不始发 | |
Catalyst交换机默认是 | VLAN信息存贮于NVRAM | |
server模式 |
3.2 VTP的运作
- VTP协议通过组播地址01-00-0C-CC-CC-CC在Trunk链路上发送VTP通告;<