主要任务是把分组从源端传到目的端,为分组交换网上的不同主机提供通信服务。网络层传输单位是IP数据报/分组。(数据报和分组是父与子的关系,数据报是比较长的数据,分组是对数据报进行切割划分出来的片段。)
功能一:路由选择与分组转发 (路由选择就是找路,通过路由选择算法找到最佳路径)
功能二:异构网络互联(网络的异构性指的是传输介质、数据编码方式、链路控制协议以及不同的数据单元格式和转发机制,这些特点分别在物理层和数据链路层中定义)
功能三:拥塞控制
通过交换网络实现数据的传递与交流。
电路交换
报文交换
分组交换
电路交换的原理:
电路交换的阶段:
举例:电话网络
特点:独占资源,用户始终占用端到端的固定传输带宽(例如A和B打电话,即使两人不讲话,这个资源也被占用)。适用于远程批处理信息传输或系统间实时性要求高的大量数据传输的情况。
电路交换优缺点:
优点:
缺点:
报文:报文(message)是网络中交换与传输的数据单元,即站点一次性要发送的数据块(源主机应用发送的信息整体,例如源主机要发送一个pdf文件,那这个pdf文件就是报文)。报文包含了将要发送的完整的数据信息,其长短很不一致,长度不限且可变。
报文交换的原理:
优点:
缺点:
分组:把大的数据块分割成小的数据块。
分组交换的原理:
优点:
缺点:
分组交换的数据传输过程可以看作流水线。计算最后一个分组到达目的主机的时延即可。
通信过程:
数据报方式的特点:
虚电路将数据报方式(体现在分组)和电路交换方式(体现在建立连接)结合,以发挥两者优点。
虚电路:一条源主机到目的主机类似于电路的路径(逻辑连接),路径上所有结点都要维持这条虚电路的建立,都维持一张虚电路表,每一项记录了一个打开的虛电路的信息。
通信过程:
虚电路方式的特点:
最佳路由:“最佳”只能是相对于某一种特定要求下得出的较为合理的选择而已。
路由算法:
静态路由算法(非自适应路由算法) 管理员手工配置路由信息
动态路由算法(自适应路由算法)路由器间彼此交换信息,按照路由算法优化出路由表项。
动态路由算法:
自治系统AS(使用内部网关协议):
路由选择协议:
采用分层路由后,路由器被划分为区域,每个路由器知道如何将分组路由到自己所在区域内的
目标地址,但对于其他区域内的结构毫不知情。当不同的网络相互连接时,可将每个网络当作一个独立的区域,这样做的好处是一个网络中的路由器不必知道其他网络的拓扑结构。
路由选择分为直接交付和间接交付,当发送站与目的站在同一网段内,就使用直接交付(对应RIP协议局域网内发送数据过程);反之使用间接交付(对应RIP协议不同局域网之间发送数据过程)。直接交付是在同一网段内,不涉及路由器。
IPv4,即现在普遍使用的IP协议(版本为4)。IP协议定义数据传送的基本单元——IP分组/IP数据报及其确切的数据格式。IP协议也包括一套规则,指明分组如何处理、错误怎样控制。特别是,IP协议还包括非可靠投递的思想(对于出错的分组丢弃并发送一个ICMP差错报文),以及与此关联的分组路由选择的思想。
IP协议:不可靠(对于出错的分组丢弃并发送一个ICMP差错报文),无连接(分组交换的数据报方式就是无连接的),采用分组交换技术(数据报方式)。
可以看出,ARP协议为IP协议服务,IP协议为ICMP和IGMP协议服务。
注意:在TCP/IP参考模型中,物理层和数据链路层一起称为网络接口层。
一个IP分组由首部和数据两部分组成。
注意:在网络层章节,IP数据报和分组不用做太详细区分。
首部固定部分各组成信息如下:
版本:版本字段长度为0-4bit;版本类型为IPv4/IPv6
首部长度(最大60B):
区分服务:指示期望获得哪种类型的服务。比如有的数据报想先发送。
总长度:首部长度+数据部分,单位是1B。总长度上限值为2^16-1=65525*1B=65525B。实际上不会达到上限值,因为长度过大时会分组,以满足数据链路层的MTU(最大数据传输单元)的要求。
生存时间(TTL:time to live):IP分组的保质期。每经过一个路由器生存时间就-1,直到变成0则丢弃。(ICMP协议中有应用)
协议:数据部分的协议,需要重点记住的是TCP字段值为6(记:面向连接,很6),UDP字段值为17(记:无连接不可靠,容易遗弃)
首部检验和:只检验首部。为什么叫首部检验和呢?因为检验首部使用的方法是使用二进制的求和,在数据传输过程中,数据报每经过一个路由器,路由器都要重新计算一下首部检验和。因为有些字段(例如生存时间,标志等)都可能发生变化,需要通过首部检验和检验一下发生变化后的数据报有没有出错,如果出错则丢弃。
源IP地址和目的IP地址:长度为32位。
可变部分信息如下:
可选字段:0~40B(可有可无,大小来源:首部最大60B-固定部分20B)。用来支持排错、测量以及安全等措施。
填充:全0,把首部补成4B的整数倍。因为首部的长度单位是4B。
链路层数据帧可封装数据的上限。例如以太网的MTU是1500字节。
如果所传送的IP数据报/分组的长度超过某链路的MTU值?——分片!所以分片的目的是为了在链路层传输的数据帧的长度不超过MTU值。
标识:同一数据报的分片使用同一标识。一个数据报的长度超过了MTU,就要进行分片,每个分片的标识相同,到了接收端就可以把同一标识的分片组合起来形成原来的数据报。
标志:3位,但只有2位有意义:x _ _ 。
片偏移:指出较长分组分片后,某片在原分组中的相对位置。以8B为单位(首部单位是4B)。可以推断:除了最后一个分片,每个分片的数据部分长度一定是8B的整数倍。
片偏移分析过程:分片长度不超过1420B,首部为20B,所以每个分片数据部分不超过1400B。原始IP数据报数据部分为3800B,可以分为3个分片:第一和二分片数据部分1400B,第三个分片数据部分1000B。另外分片的首部长度与原始数据报的首部长度相同都为20B。
片偏移 = 数据部分起始字节/单位8B
总长度单位是1B,首部长度单位是4B,片偏移单位是8B。
主机A要与其主机B通信,就要知道主机B在哪个网络?是哪个主机?IP地址就是给网络中的每一个主机或者说每一个主机的接口以及路由器的接口都赋予一个全球唯一化的标识符。
分类的IP地址——子网的划分——构成超网(无分类编址方法)
IP地址组成:
身份证号码:110000199601010442 六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码
IP地址:全世界唯一的32位/4字节标识符,标识路由器主机的接口。
互联网中的IP地址:
左边黄色区域:网络号为222.1.3.0,主机号分别是222.1.3.1、222.1.3.2、222.1.3.3
图中的每一个路由器有三个IP地址,因为路由器的每个接口都有一个IP地址。
绿色区域也可以称为网络,叫做无编号网络(有IP地址,但是由一段线构成)。
分类的IP地址:
D类地址是多播地址:在一对多通信的时候使用的地址。(IP组播地址会讲到)
A类网络号范围1~126:A类网络号占8位,又因为第一位必须为0,所以后7位可以组2^7=128个网络号,范围为0~2^7-1=127。其中网络号全0表示本网,127表示环回地址,故A类地址网络号范围为1~126。
B类网络号范围128~191:前两位必须为10,所以后6位可以组2^6=64个网络号,第一个网络号是128,最大网络号为128+(2^6-1)=191。
C类网络号范围192~223:前两位必须为110,所以后5位组成最大网络号为192+(2^5-1)=223。
特殊IP地址:
网络号全0:本网
网络号全1且主机号全1:本网广播地址,作为目的地址,但路由器不转发。
网络号特定值,主机号全0:表示一个网络(没有主机号,只单纯表示网络,所以没源地址和目的地址)
网络号特定值,主机号全1:表示广播地址,可以作为目的地址(目的地址为所有主机)
私有IP地址:
路由器对目的地址是私有IP地址的数据报一律不进行转发。要与外部互联网建立通信,需要通过网络地址转换NAT。
不同类的IP地址特点:
分类的IP地址的弱点:
有没有一种办法可以随时随地,灵活增加本单位的网络,不需要事先去ISP申请新的网络号呢?可以使用子网划分!
划分子网思想:
子网掩码:无论是二级IP地址还是三级IP地址,只要是网络号就全写1(子网号也全写1,注意并不是第三个字节八位都是子网号都写1,而是主机号当中较高的位数作为子网号才写1),只要是主机号就全0。
如何判断IP数据报通过路由器分给哪个子网网络地址?——子网掩码与IP地址逐位相与,就得到子网网络地址。(IP地址:网络号+主机号;网络地址:网络号)
1、已知目的IP地址是141.14.72.24,子网掩码是255.255.192.0, 求网络地址。如果子网掩码是255.255.224.0,求网络地址。
此题为已知目的地址,求子网网络地址。对于第一问:
第二问同理得子网网络地址为141.14.64.0。
2、某主机的IP地址为180.80.77.55,子网掩码为255.255.252.0。若该主机向其所在子网发送广播分组,则目的地址可以是( )。
A.180.80.76.0 B. 180.80.76.255 C. 180.80.77.255 D. 180.80.79.255
此题为求同一子网内的目的地址。
外部来了一个分组,经过路由器应该如何转发,才能把分组正确的送到子网内对应的主机上?
路由器转发分组的算法:
又称为无分类域间路由选择CIDR(Classless Inter-Domain Routing)
1.消除了传统的A类,B类和C类地址以及划分子网的概念。
CIDR记法: IP地址后加上“/”,然后写上网络前缀(可以任意长度)的位数。e.g. 128.14.32.0/20:表示前20位是网络号,后12位是主机号。
2.融合子网地址与子网掩码,方便子网划分。CIDR把网络前缀都相同的连续的IP地址组成一个“CIDR地址块”。
例如128.14.35.7/20是某CIDR地址块中的一个地址
地址块(网络前缀):最小地址/网络前缀大小,128.14.35.0/20。不需要指出起始地址时,可以记为“/20地址块”
举例:求192.199.170.82/27的地址块
地址掩码(子网掩码):11111111 11111111 11110000 00000000 (网络前缀全1,主机号全0)
将多个子网聚合成一个较大的子网,叫做构成超网,或路由聚合。
方法:将网络前缀缩短。
R1给网络1和网络2发送信息,需要查看自己的转发表有没有到达网络1和网络2的路径,以及对应的下一跳地址是多少。
构成超网前转发表:第一行网络前缀为网络1的IP地址,下一跳地址为R2;第二行网络前缀为网络2的IP地址,下一跳地址也是R2。
如果R2连接的网络非常多,那么路由器转发表就会变得异常庞大。既然第一行和第二行的下一跳地址都是R2,那么有什么办法可以将下一跳地址相同的网络合并为一行呢?——构成超网(将网络前缀相同的部分合并为共同网络前缀,即缩短前缀。)
如何将网络前缀缩短(合并为共同网络前缀):网络1和网络2前16位相同,网络1第三个字节二进制为00000000,网络2第三个字节二进制为10000000。将网络前缀由17缩短到16位后地址块(最小地址/网络前缀大小)为:206.1.0.0/16,此时就将网络1和网络2合并为超网。
构成超网后的转发表:网络前缀为206.1.0.0/16,下一跳地址为R2。
在实际发送数据时,要用数据报当中的目的地址来和转发表中的网络前缀进行匹配,因为我们构成了超网,之前具体的网络1和网络2现在合并变成了超网,因此在匹配时,会发现在转发表中有好几行都是可以匹配的,这时就需要决定,应该选择哪一个,从哪一跳走出去。——最长前缀匹配
使用CIDR时,查找路由表可能得到几个匹配结果,应选择具有最长网络前缀的路由。前缀越长,地址块越小,路由越具体。
例题:路由器R0的路由表见下表:若进入路由器R0的分组的目的地址为132.19.237.5,请问该分组,应该被转发到哪一个下一跳路由器(B ) 。
A. R1 B. R2 C. R3 D. R4
R1:目的网络的网络前缀为前8位,与目的地址的前8位相同,所以目的地址可以被转发到R2路由器。
R2:网络前缀为前11位,目的地址第二个字节二进制为00010011,目的地址前11位与网络地址前11位相同,所以可以转发到R2路由器。
R3:网络前缀为前22位,第三个字节二进制为11101000。目的地址第三个字节为11101101。第22位不相同,即网络前缀不相同,所以目的地址不能转发到R3路由器。
R4:网络号全0,主机号全0表示默认路由,当目的地址与转发表都不匹配时,交给默认路由,然后去别的路由器的转发表找查找与目的地址匹配的网络。
查找路由表可能得到几个匹配结果,应选择具有最长网络前缀的路由。综上,答案是B。
习题:某网络的IP地址空间为192.168.5.0/24, 采用定长子网划分,子网掩码255.255.255.248, 则该网络中的最大子网个数、每个子网内的最大可分配地址个数分别是( B )。
A. 32,8 B.32,6 C.8,32 D. 8,30
注意:1.CIDR地址块中子网号可以全0全1。2.地址个数需要减2(主机号全0表示网络,主机号全1表示广播地址)。
Address Resolution Protocol:地址解析协议
1号主机给3号主机发送数据过程:
ARP高速缓存:局域网内部主机IP地址与MAC地址的映射
ARP协议过程:
不在一个局域网内部,1号主机和5号主机通信过程:
1、ARP高速缓存存储的是局域网内部IP地址与MAC地址的映射,1号主机IP地址与5号主机IP地址相与,发现与5号主机不在同一网段内。
2、目的地址为默认网关的MAC地址:1号主机查询默认网关(与外界沟通的路由器)的MAC地址MAC6,并添入到目的地址。
3、到IP6路由器后,IP地址不变,再次通过ARP 协议得到第二个路由器的MAC地址MAC8,源地址就变成MAC7,目的地址就变成MAC8。
4、到第二个路由器后,还是通过ARP协议得到MAC5。源地址就变成MAC9,目的地址就变成MAC5。
为什么使用ARP协议:由于在实际网络的链路上传送数据帧时,最终必须使用MAC地址。
ARP协议功能:完成主机或路由器IP地址到MAC地址的映射。解决下一跳走哪的问题。
ARP协议使用过程:
ARP协议4种典型情况:
ARP协议为IP协议提供服务:ARP协议是处于链路层和网络层中间的协议,因为它结合了IP地址和MAC地址。主要划分到网络层,为IP协议提供服务。
主机发送IP数据报给主机B,经过了5个路由器,请问此过程总共使用了几次ARP协议?——6次
如果路由器之间是点对点协议,则2次。
动态主机配置协议:Dynamic Host Configuration Protocol
DHCP协议概念:动态主机配置协议DHCP是应用层协议,使用客户/服务器方式,客户端和服务端通过广播方式进行交互,基于UDP。
DHCP协议功能:DHCP提供即插即用联网的机制,主机可以从服务器动态获取IP地址、子网掩码、默认网关、DNS服务器名称与IP地址,允许地址重用,支持移动用户加入网络,支持在用地址续租。
DHCP协议流程:
Internet Control Message Protocol:互联网控制报文协议
ICMP协议作用:为了更有效地转发IP数据报和提高交付成功的机会。
ICMP协议支持主机或路由器:
ICMP协议功能:
ICMP报文种类:ICMP差错报文、ICMP询问报文。
ICMP报文格式:
五种类型:
1.终点不可达:当路由器或主机不能交付数据报时就向源点发送终点不可达报文。无法交付
2.源点抑制(取消):当路由器或主机由于拥塞而丢弃数据报时,就向源点发送源点抑制报文,使源点知道应当把数据报的发送速率放慢。拥塞丢数据时告诉源点慢点
3.时间超过:当路由器收到生存时间TTL=0的数据报时,除丢弃该数据报外,还要向源点发送时间超过报文。当终点在预先规定的时间内不能收到一个数据报的全部数据报片时,就把已收到的数据报片都丢弃(保证一家人整整齐齐),并向源点发送时间超过报文。TTL=0和不完整
4.参数问题:当路由器或目的主机收到的数据报的首部中有的字段的值不正确时,就丢弃该数据报,并向源点发送参数问题报文。首部字段有问题
5.改变路由(重定向):路由器把改变路由报文发送给主机,让主机知道下次应将数据报发送给另外的路由器(可通过更好的路由)。值得更好的路由
发送ICMP差错报文的情况:对于出错的IP数据报丢弃并发送一个ICMP差错报文。
ICMP差错报文组成:ICMP报文的前8字节(类型)+出错的IP数据报首部+数据字段前8字节。ICMP差错报文是IP数据报的数据部分
不应发送ICMP差错报文的情况:
1.回送请求和回答报文
2.时间戳请求和回答报文:请某个主机或路由器回答当前的日期和时间。用来进行时钟同步和测量时间。
3.掩码地址请求和回答报文(不再使用)
4.路由器询问和通告报文(不再使用)
PING:测试两个主机之间的连通性,使用了ICMP回送请求和回答报文。
Traceroute:跟踪一个分组从源点到终点的路径,使用了ICMP时间超过差错报告报文。
1.32位的IPv4地址空间已分配殆尽,无分类编址CIDR和网络地址转换NAT方法治标不治本。
2.改进首部格式:之前的IPv4首部部分20字节的字段太多,通过改进首部格式达到快速处理/转发数据报。
3.支持QoS:QoS ( Quality of Service,服务质量)指个网络能够利用各种基础技术,为指定的网络通信提供更好的服务能力,是网络的一种安全机制,是用来解决网络延迟和阻塞等问题的一种技术。
一般形式冒号十六进制记法:4BF5:AA12:0216:FEBC:BA5F:039A:BE9A:2170(每4位bit用一个16进制表示,2^4=16,一个16进制数刚好可以表示完4位。每4*4=16位=2B一组,用冒号隔开)
压缩形式:4BF5:0000:0000:0000:BA5F:039A:000A:2176——4BF5:0:0:0:BA5F:39A:A:2176。
零压缩形式:一连串连续的0可以被一对冒号取代
单播:一对一通信 可做源地址+目的地址
多播:一对多通信 可做目的地址 (取代了IPv4的广播)
任播:一对多中的一个通信 可做目的地址 (通常是离发送方最近的主机)
双栈协议:双协议栈技术就是指在一台设备上同时启用IPv4协议栈和IPv6协议栈。这样的话,这台设备既能和IPv4网络通信,又能和IPv6网络通信。如果这台设备是一个路由器,那么这台路由器的不同接口上,分别配置了IPv4地址和IPv6地址,并很可能分别连接了IPv4网络和IPv6网络。如果这台设备是一个计算机,那么它将同时拥有IPv4地址和IPv6地址,并具备同时处理这两个协议地址的功能。
隧道技术:通过使用互联网络的基础设施在网络之间传递数据的方式。使用隧道传递的数据(或负载)可以是不同协议的数据帧或包。隧道协议将其它协议的数据帧或包重新封装然后通过隧道发送。
路由选择协议分类回顾:
RIP协议(Routing Information Protocol:路由信息协议):是一种分布式的基于距离向量算法的路由选择协议,是因特网的协议标准,最大优点是简单。
记录最佳距离:RIP协议要求网络中每一个路由器都维护从它自己到其他每一个目的网络的唯一最佳距离记录(即一组距离)。
距离(最多15个路由):通常为“跳数”,即从源端口到目的端口所经过的路由器个数,经过一个路由器跳数+1。特别的,从一路由器到直接连接的网络距离为1(也有的书是0)。RIP允许一条路由最多只能包含15个路由器,因此距离为16表示网络不可达。所以RIP协议只适用于小互联网。
R2的路由表记录如下:
和谁交换?1.仅和相邻路由器交换信息。
交换什么?2.路由器交换的信息是自己的路由表(路由器把自己的路由表信息放到一个RIP报文里面,发送给相邻路由器)。
多久交换一次?3.每30秒交换一次路由信息,然后路由器根据新信息更新路由表。若超过180s没收到邻居路由器的通告,则判定邻居没了,并更新自己路由表。
交换过程:
RIP报文:RIP报文包含的信息就是路由表的全部信息,每两个路由表之间交换信息其实就是交换的RIP报文。
距离向量算法过程:
1.修改相邻路由器发来的RIP报文中所有表项
对地址为X的相邻路由器发来的RIP报文,修改此报文中的所有项目:把“下一跳”字段中的地址改为X,并把所有的“距离”字段+1。
2.对修改后的RIP报文中的每一个项目,进行以下步骤:
(1) 原R1路由表中若没有Net3,则把该项目直接填入R1路由表。
(2) 原R1路由表中若有Net3,则查看下一跳路由器地址(看一下新的情况是怎么样的):
3.若180s还没收到相邻路由器X的更新路由表,则把X记为不可达的路由器,即把距离设置为16。
4.返回
RIP的特点:当网络出现故障时,要经过比较长的时间(例如数分钟)才能将此信息传送到所有的路由器,“慢收敛”。
开放最短路径优先OSPF(Open shortest path first)协议:“开放”标明OSPF协议不是受某一家厂商控制,而是公开发表的;“ 最短路径优先”是因为使用了Dijkstra(迪杰斯特拉)提出的最短路径算法SPF。(该算法十分重要,多次出现)
OSPF最主要的特征就是使用分布式的链路状态协议。
OSPF的特点:
和谁交换?1.使用洪泛法(洪水泛滥)向自治系统内所有路由器发送信息,即路由器通过输出端口向所有相邻的路由器发送信息,而每一个相邻路由器又再次将此信息发往其所有的相邻路由器。类似广播——最终整个区域内所有路由器都得到了这个信息的一个副本。而RIP仅和相邻路由器交换信息。
交换什么?2.发送的信息就是与本路由器相邻的所有路由器的链路状态(本路由器和哪些路由器相邻,以及该链路的度量/代价——费用、距离、时延、带宽等)。而RIP交换的信息是自己的路由表
多久交换?3.只有当链路状态发生变化时,路由器才向所有路由器洪泛发送此信息进行交换。而RIP是每30s路由表交换一次。
最后,所有路由器都能建立一个链路状态数据库,即全网拓扑图。
OSPF的五个重要分组:
1.每个路由器发现它的邻居结点[通过每10s发送HELLO问候分组来发现邻居结点],并了解邻居节点的网络地址。
2.设置到它的每个邻居的成本度量metric(n. 度量标准)。
3.构造[DD数据库描述分组],向邻站给出自己的链路状态数据库(全网的拓扑结构图)中的所有链路状态项目的摘要信息。
4.如果DD分组中的摘要邻站自己都有,则邻站不做处理;如果有没有的或者有更新的,则邻站发送[LSR链路状态请求分组]请求自己没有的和比自己更新的信息。
5.收到邻站的LSR分组后,路由器发送[LSU链路状态更新分组]进行更新。
6.更新完毕后,邻站返回一个[ LSAck链路状态确认分组]进行确认。
网络拓扑不是一成不变的,只要一个路由器的链路状态发生变化:
5.泛洪发送[LSU链路状态更新分组]进行更新。
6.更新完毕后,其他站返回一个[ LSAck链路状态确认分组]进行确认。
7.使用Dijkstra根据自己的链路状态数据库构造到其他节点间的最短路径。
为了使OSPF能够用于规模很大的网络,OSPF将一个自治系统再划分为若干个更小的范围,叫做区域。每一个区域都有一个32位的区域标识符(用点分十进制表示)。
区域也不能太大,在一个区域内的路由器最好不超过200个。适用于规模比较大的自治系统。
1.每隔30min,要刷新一次数据库中的链路状态。
2.由于一个路由器的链路状态只涉及到与相邻路由器的连通状态,因而与整个互联网的规模并无直接关系。因此当互联网规模很大时,OSPF协议要比距离向量协议RIP好得多。
3.OSPF不存在坏消息传的慢的问题,它的收敛速度很快。
Border Gateway Protocol:边界网关协议
和谁交换? 与其他AS的邻站BGP发言人交换信息。
交换什么? BGP发言人之间交换的网络可达性的信息,即要到达某个网络所要经过的一系列AS。
多久交换? 发生变化时更新有变化的部分。
BGP所交换的网络可达性的信息就是要到达某个网络所要经过的一系列AS。当BGP发言人互相交换了网络可达性的信息后,各BGP发言人就根据所采用的策略从收到的路由信息中找出到达各AS的较好路由(不需要最好,因为网络环境复杂)。
对于AS1自治系统来说,有一个边界路由器作为BGP发言人,即使用BGP协议,同时也使用内部网关协议RIP或OSPF。
BGP发言人交换路径向量(交换一组路径的信息可以看作交换路径的一个向量):
一个BGP发言人与其他自治系统中的BGP发言人要交换路由信息,就要先建立TCP连接,即通过TCP传送(为什么使用TCP而不是UDP,因为使用TCP可以提供更加可靠的服务,简化路由选择协议), 然后在此连接上交换BGP报文以建立BGP会话(session),利用BGP会话交换路由信息。
BGP是应用层协议(看到报文就知道是应用层协议),借助传输层TCP传送。
BGP路由表:BGP支持无分类路由选择CIDR,因此BGP的路由表也就应当包括目的网络前缀、下一跳路由器,以及到达该目的网络所要经过的各个自治系统序列。
交换内容:在BGP刚刚运行时,BGP的邻站是交换整个的BGP路由表。但以后只需要在发生变化时更新有变化的部分(多久交换)。这样做对节省网络带宽和减少路由器的处理开销都有好处。
1.OPEN (打开)报文:用来与相邻的另一个BGP发言人建立关系(BGP报文需要借助TCP连接,OPEN报文就是在实现连接的建立),并认证发送方。
2.UPDATE (更新)报文:通告新路径或撤销原路径。
3.KEEPALIVE(保活/确认存活)报文:在无UPDATE时(可能很长一段时间都不会给对方发送报文,又想知道对方是不是在线),周期性证实邻站的连通性;也作为OPEN的确认。
4.NOTIFICATION (通知)报文:报告先前报文的差错;也被用于关闭连接。
RIP是一种分布式的基于距离向量的内部网关路由选择协议,通过广播UDP报文(传输层)来交换路由信息。
OSPF是一个内部网关协议,要交换的信息量较大,应使报文的长度尽量短,所以不使用传输层协议(如UDP或TCP),而是直接采用网络层IP。
BGP是一个外部网关协议,在不同的自治系统之间交换路由信息,由于网络环境复杂,需要保证可靠传输,所以采用传输层TCP。
单播:单播用于发送数据包到单个目的地,且每单播发送一份单播报文都使用一个单播IP地址作为目的地址。是一种点对点传输方式。
广播:广播是指发送数据包到同一广播域或子网内的所有设备的一种数据传输方式,是一种点对多点传输方式。(源地址是单播IP地址,目的地址是全1广播地址)
组播(多播):当网络中的某些用户需要特定数据时,组播数据发送者仅发送一次数据,借助组播路由协议为组播数据包建立组播分发树,被传递的数据到达距离用户端尽可能近的节点后才开始复制和分发,是一种点对多点传输方式。(到最后一步,一个数据报才会被复制成多个数据报,分发给各主机)
分析:我们知道,在因特网中进行通信时,每个主机都有一个全球唯一的IP地址。如果组播组中的某个主机想接收组播数据报,组播数据报如何才能传到该主机中呢?组播数据报的目的地址肯定不能只写该主机的IP地址,因为这样写,只会发给这一个主机,其他的同处于多播组的主机收不到该数据报。因此,需要在该主机中产生一个IP组播地址,来接收组播数据报。
IP组播地址:IP组播地址让源设备能够将组播数据报发送给一组设备。即属于多播组的设备将被分配同一个组播组IP地址(一群共同需求主机的相同标识)。
组播地址范围:组播地址范围为224.0.0.0~239.255.255.255(D类地址),一个D类地址表示一个组播组。只能用作分组的目的地址。源地址总是为单播地址。
IP组播数据报特点:
IP组播可以分为两个部分,一部分是因特网范围内组播,一部分是局域网内部硬件组播。现在大部分主机都是通过连接局域网然后再连接因特网,所以最后通过因特网范围内组播之后还是要进入到局域网内的硬件组播。
硬件组播:硬件组播说的其实就是在局域网范围内,对于一个组播数据报,应该怎么发给这些主机或者说给哪些主机。
组播MAC地址如何得到?:比如现在发来一个单播数据报,进入局域网后应该交给哪个主机?要看主机的MAC地址。同单播地址一样,组播IP地址也需要相应的组播MAC地址在本地网络中实际传送帧。组播MAC地址(48位=6B)以十六进制值01-00-5E(固定)打头,余下的6个十六进制位是根据IP组播组地址(D类IP地址)的最后23位转换得到的。
TCP/IP协议使用的以太网多播MAC地址的范围是:从01-00-5E-00-00-00到01-00-5E-7F-FF-FF
不同IP地址可能映射成同一MAC地址:可以发现,IP地址不能使用的5位可以构成2^5=32个IP地址。如果这32个主机后面23位一样,那么这32个IP地址映射到多播MAC地址上就是一样的。也就是说,会导致32个不同的IP地址映射成了同一个MAC地址。如何解决?——进行过滤
过滤:收到多播数据报的主机,还要在IP层利用软件进行过滤,把不是本主机要接收的数据报丢弃。
IGMP协议:
组播路由选择协议:
这两个协议其实就是在因特网范围内组播组要使用到的一些协议。
Internet group management protocol:网际组管理协议
IGMP协议作用:IGMP协议让路由器知道本局域网上是否有主机(的进程)参加或退出了某个组播组。
ICMP和IGMP都使用IP数据报传递报文。
IGMP工作的两个阶段:
ROUND 1:
主机向组播组地址发送IGMP报文表示要加入:某主机要加入组播组时,该主机向组播组的组播地址发送一个IGMP报文,声明自己要成为该组的成员。
加入后,也要告诉其他在组播组中的路由器呀:本地组播路由器收到IGMP报文后,要利用组播路由选择协议把这组成员关系发给因特网上的其他组播路由器。
ROUND 2:
定期探询,各主机是否还是组播组成员:本地组播路由器周期性探询(发送IGMP询问报文)本地局域网上的主机,以便知道这些主机是否还是组播组的成员。既然是询问,结果就有两种!
成员关系:组播路由器知道的成员关系只是所连接的局域网中有无组播组的成员。 但是并不知道这一组成员有多少个,可以通过组播路由选择协议知道。
一个组播组中的成员是动态变化的,比如突然加入或者突然离开。就像看电视一样,换台。组播路由选择协议目的是找出以源主机为根节点的组播转发树。
组播转发树:组播路由协议目的是找出以源主机为根节点的组播转发树。
组播路由选择协议常使用的三种算法:
使用VPN的原因:由于IP地址的紧缺,以及互联网并不安全,一个机构内也不需要把所有主机接入互联网。大部分情况下,主机主要是和本机构内的其他主机进行通信。
VPN原理:假定在一个机构内部的计算机通信也是采用TCP/IP协议,那么从原则上讲,对于这些仅在机构内部使用的计算机就可以由本机构自行分配其IP 地址。这就是说,让这些计算机使用仅在本机构有效的IP地址(这种地址称为本地地址),而不需要向互联网的管理机构申请全球唯一的IP地址(这种地址称为全球地址)。
本地地址使用的就是私有IP地址:
虚拟专用网VPN(Virtual Private Network):利用公用的互联网作为本机构各专用网之间的通信载体。
利用IP隧道技术实现虚拟专用网:
内联网、外联网和远程接入VPN:
下面讨论另一种情况,就是在专用网内部的一些主机本来已经分配到了本地IP 地址(即仅在本专用网内使用的专用地址),但现在又想和互联网上的主机通信(并不需要加密),那么应当采取什么措施呢?
网络地址转换NAT ( Network Address Translation) :在专用网连接到互联网的路由器上安装NAT软件,安装了NAT 软件的路由器叫NAT路由器,它至少有一个有效的外部全球IP地址。
数据传输过程:传输层报文段(携带端口信息)传到网络层,网络层封装为IP数据报,通过数据链路层传输到目的主机后,目的主机的传输层解封装取得端口号。
其中网络层地址转换过程如下:
路由器是一种具有多个输入端口和多个输出端口的专用计算机,其任务是转发分组。
路由选择处理机:根据所选定的路由选择协议构造出路由表,同时经常或定期地和相邻路由器交换路由信息而不断地更新和维护路由表。
交换结构:根据转发表(路由表得来)对分组进行转发。
转发VS路由选择:转发在路由器内部,把一个分组从一个输入端口转发到一个输出端口;路由选择在路由之间选一个合适的路径,把数据从源主机发送到目的主机。
分组分为路由交换信息的分组和数据分组:不是所有分组都从一个输入端口转发到一个输出端口,若收到RIP/OSPF分组(路由器之间交换信息的分组)等, 则把分组送往路由选择处理机;若收到数据分组,则查找转发表并输出。
输入端口对线路上收到的分组的处理过程:
输出端口的处理过程:
路由器:可以互联两个不同网络层协议的网段。
网桥:可以互联两个物理层和链路层不同的网段。
集线器:傻瓜设备,不能互联两个物理层不同的网段。
路由表(下一跳走哪):路由表根据路由选择算法得出的,主要用途是路由选择,总用软件来实现。
默认路由:只要发送的分组在路由表中找不到对应的下一跳IP地址,就应该发给默认路由。
转发表:转发表由路由表得来,可以用软件实现,也可以用特殊的硬件来实现。转发表必须包含完成转发功能所必需的信息,在转发表的每一行必须包含从要到达的目的网络到输出端口和某些MAC地址信息的映射。
安全管理措施:为了保证路由器最基本的安全,需要在路由器上采取设置访问控制列表和升级IOS进行安全补漏的安全管理措施。(路由器安全是针对黑客入侵的逻辑安全)