鉴于有人需要离线版的PDF文档,这里给出本文章的PDF版本,下载地址如下:https://pan.itnxd.cn/123Pan/csdn-share/computer-network.pdf
计算机网络是 互连的、自治的 计算机系统的集合。
计算机网络是一个将分散的、具有独立功能的计算机系统,通过通信设备和线路连接起来,由功能完善的软件实现资源共享和信息传递的系统。
网络把许多计算机连接在一起,而互联网则把许多网络连接在一起,因特网是世界上最大的互联网。
组成部分:
工作方式:
边缘部分(用户直接使用)
核心部分(为边缘部分服务)
功能组成:
法定标准:由权威机构指定的正式的、合法的标准 OSI
事实标准:某些公司的产品在竞争中占据了主流,时间长了,这些产品中的协议和技术就成了标准 TCP/IP
RFC(Request For Comments):因特网标准的形式
RFC要上升为因特网正式标准的四个阶段:
速率:连接在计算机网络上的主机在数字信道上传送数据的速率。
也称数据率或数据传输率或比特率.
单位:是b/s(bit/s、bps),kb/s,Mb/s,Gb/s,Tb/s
速率单位
千 1kb/s = 10^3 b/s 1KB = 2^10B = 1024B = 1024 * 8b
兆 1Mb/s = 10^3 kb/s = 10^6 b/s 1MB = 2^10KB = 1024KB
吉 1Gb/s = 10^3 Mb/s = 10^6 kb/s = 10^9 b/s 1GB = 2^10MB = 1024MB
太 1Tb/s = 10^3Gb/s = 10^6 Mb/s = 10^9 kb/s = 10^12 b/s 1TB = 2^10GB = 1024GB
容量单位
1KB = 2^10B = 1024B = 1024 * 8b
1MB = 2^10KB = 1024KB
1GB = 2^10MB = 1024MB
1TB = 2^10GB = 1024GB
带宽:在计算机网络中,表示数字信道所能传送的"最高数据传输速率",单位是比特每秒。
原本指某个信号具有的频带宽度,即最高频率与最低频率之差,单位是赫兹(Hz)。
理论值
带宽只影响进入链路的一瞬间,进入链路后则是固定的速度,即电磁波的传播速度!
吞吐量:单位时间内,通过某个**网络(或信道、接口)**的数据量。实际的数据传输率!
吞吐量受网络带宽或网络额定速率的限制。
实际值
时延:指数据(报文/分组/比特流)从网络(链路)的一端传送到另一端所需要的时间。单位是s。
1、发送时延(传输时延):结点将分组的所有比特传输到链路上所需的时间。
从发送分组的第一个比特算起,到该分组的最后一个比特发送完毕所需的时间。
计算公式为 :发送时延 = 分组长度 / 信道带宽
2、传播时延:电磁波在信道中传播一定的距离需要花费的时间
即一个比特从链路的一段传播到另一端所需的时间。
计算公式为:传播时延 = 信道长度 / 电磁波在信道上的传播速率(一般为固定值 2 * 10^8 m/s)
3、处理时延:数据在交换结点为存储转发而进行的一些必要的处理(检错,找出口)所花费的时间。
例如,分析分组的首部、从分组中提取数据部分、进行差错检验或查找适当的路由等
4、排队时延:分组在进入路由器后要先在输入队列中排队等待处理。路由器确定转发端口后,还要在输出队列中排队等待转发,产生排队时延。
时延带宽积:指发送端发送的第一个比特即将到达终点时,发送端已经发出了多少个比特
又称以比特位单位的链路长度,即
时延带宽积 = 传播时延 x 信道带宽
往返时延(Round-Trip Time,RTT):指发送端发送数据开始,到发送端收到来自接受端的确认,总共经历的时延。
RTT越大,在收到确认之前,可以发送的数据越多!
RTT包括 = 2 * 传播时延(往返传播时延) + 末端处理时延
信道利用率:指出某一信道有百分之多少的时间是有数据通过的。
信道利用率 = 有数据通过的时间/(有+无)数据通过时间
网络利用率:信道利用率的加权平均值
计算机网络的各层及其协议的集合称为网络的体系结构。
网络体系结构是从功能上描述计算机网络结构。
计算机网络体系结构简称网络体系结构是分层结构。
分层的基本原则
分层结构
1、实体:第n层中的活动元素称为n层实体。同一层的实体叫对等实体。
2、协议:为进行网络中的对等实体数据交换而建立的规则、标准或约定。【水平】
3、接口(服务访问点 SAP):上层使用下层服务的入口。
4、服务:下层为相邻上层提供的功能调用。【垂直】
在计算机网络体系结构的各个层次中,每个报文都分为两部分:
一是数据部分,即SDU;二是控制信息部分,即PCI,它们共同组成PDU。
第n层在向n+1层提供服务时,此服务不仅包含第n层本身的功能,还包含下层服务提供的功能。
仅仅在相邻层间有接口,且所提供服务的具体实现细节对上一层完全屏蔽。
为了解决计算机网络复杂的大问题 ----> 分层结构(按功能)
目的:支持异构网络系统的互联互通。
国际标准化组织(ISO)于1984年提出开放系统互连(OSI)参考模型。
但是理论成功,市场失败。
上面四层是端到端,下面三层是点到点。
应用层:所有能和用户交互产生网络流量的程序,是用户与网络的界面。
表示层:处理在两个通信系统中交换信息的表示方式(语法和语义)。
会话层:向表示层实体/用户进程提供建立连接并在连接上有序地传输数据,这是会话,也是建立同步(SYN)。
传输层:负责主机中两个进程的通信,即端到端的通信。传输单位是报文段或用户数据报。
网络层(IP层、网继层):把分组从源端传到目的端,为分组交换网上的不同主机提供通信服务。网络层传输单位是数据报。
数据链路层:把网络层传下来的数据报组装成帧。
物理层:在物理媒体上实现比特流的透明传输。
相同点
不同点
面向连接分为三个阶段,第一是建立连接,在此阶段,发出一个建立连接的请求。只有在连接成功建立之后,才能开始数据传输,这是第二阶段。接着,当数据传输完毕,必须释放连接。
而面向无连接没有这么多阶段,它直接进行数据传输。
应用层:支持各种网络应用 ----- FTP、SMTP、HTTP
传输层:进程-进程的数据传输 ----- TCP、UDP
网络层:源主机到目的主机的数据分组路由与转发 ----- IP、ICMP、OSPF
数据链路层:把网络层传下来的数据报组装成帧 ----- Ethernet、PPP
物理层:比特传输
通信过程
物理层解决如何在连接各种计算机的传输媒体上传输数据比特流,而不是指具体的传输媒体。
物理层主要任务:确定与传输媒体接口有关的一些特性。(定义标准)
通信的目的是传送信息。
数据:传送信息的实体,通常是有意义的符号序列。
信号:数据的电气/电磁的表现,是数据在传输过程中的存在形式。
信源:产生和发送数据的源头。
信宿:接收数据的终点。
信道:信号的传输媒介。一般用来表示向某一个方向传送信息的介质。
三种通信方式
串行传输:速度慢,费用低,适合远距离
并行传输:速度快,费用高,适合近距离(常用于计算机内部数据传输)
码元是一个固定时长的信号波形(数字脉冲),代表不同离散数值的基本波形,是数字通信的计量单位,这个时长内的信号称为k进制码元,而该时长称为码元宽度。当码元的离散状态有M个时(M大于2),此时码元为M进制码元。
1码元可以携带多个比特的信息量。例如,在使用二进制编码时,只有两种不同的码元,一种代表0状态,另一种代表1状态。
例子
4进制码元 -> 码元的离散状态有4个 -> 4种高低不同的信号波形 -> 00、01、10、11
速率也叫数据率,是指数据的传输速率,表示单位时间内传输的数据量。可以用码元传输速率和信息传输速率表示。
码元传输速率:别名码元速率、调制速率、符号速率等,它表示单位时间内数字通信系统所传输的码元个数(也可称为脉冲个数或信号变化的次数),单位是波特(Baud)。1波特表示数字通信系统每秒传输一个码元。码元速率与进制数无关。【1秒传输多少个码元】
1Baud = 1码元/s
信息传输速率:别名信息速率、比特率等,表示单位时间内数字通信系统传输的二进制码元个数(即比特数),单位是比特/秒(b/s) .【1秒传输多少个比特】
关系:若一个码元携带n bit的信息量,则M Baud的码元传输速率所对应的信息传输速率为M x n bit/s。
带宽:表示在单位时间内从网络中的某一点到另一点所能通过的“最高数据率”,常用来表示网络的通信线路所能传输数据的能力。单位是b/s。
影响失真程度的因素:
码元传输速率
信号传输距离
噪声干扰
传输媒体质量
码间串扰:接收端收到的信号波形失去了码元之间清晰界限的现象。
在理想低通(无噪声,带宽受限)条件下,为了避免码间串扰,极限码元传输速率为 2W Baud,W 是信道带宽,单位是 Hz。(只有在这两个公式中带宽才用Hz)
例子
噪声存在于所有的电子设备和通信信道中。由于噪声随机产生,它的瞬时值有时会很大,因此噪声会使接收端对码元的判决产生错误。但是噪声的影响是相对的,若信号较强,那么噪声影响相对较小。因此信噪比就很重要。
信噪比 = 信号的平均功率/噪声的平均功率,常记为 S/N,并用分贝(dB)作为度量单位,即:
香农定理:在带宽受限且有噪声的信道中,为了不产生误差,信息的数据传输速率有上限值。
信道:信号的传输媒介。一般用来表示向某一个方向传送信息的介质,因此一条通信线路往往包含一条发送信道和一条接收信道。
基带信号:将数字信号1和0直接用两种不同的电压表示,再送到数字信道上去传输(基带传输)。来自信源的信号,如计算机输出的代表各种文字或图像文件的数据信号都属于基带信号。基带信号就是发出的直接表达了要传输的信息的信号。比如声波!
宽带信号:将基带信号进行调制后形成的频分复用模拟信号,再传送到模拟信道上去传输(宽带传输)。把基带信号经过载波调制后,把信号的频率范围搬移到较高的频段以便在信道中传输。
编码:数据转成数字信号
调制:数据转成模拟信号
数字数据
模拟数据
1、非归零编码【NRZ】
高1低0。编码容易实现,但没有检错功能,且无法判断一个码元的开始和结束,以至于收发双方难以保持同步。例如全0或全1,是一条水平线
2、曼彻斯特编码
将一个码元分成两个相等的间隔,前一个间隔为低电平后一个间隔为高电平表示码元1;码元0则正好相反。也可以采用相反的规定。该编码的特点是在每一个码元的中间出现电平跳变,位中间的跳变既作时钟信号(可用于同步),又作数据信号,但它所占的频带宽度是原始的基带宽度的两倍。每一个码元都被调成两个电平,所以数据传输速率中有调制速率的1/2。(一个人时钟周期内,一个比特,两个码元)
3、差分曼彻斯特编码
同1异0。常用于局域网传输,其规则是:若码元为1,则前半个码元的电平与上一个码元的后半个码元的电平相同,若为0,则相反。该编码的特点是,在每个码元的中间,都有一次电平的跳转,可以实现自同步,且抗干扰性强于曼彻斯特编码。
4、归零编码【RZ】
信号电平在一个码元之内都要恢复到零。
5、反向不归零编码【NRZI】
信号电平翻转表示0,信号电平不变表示1。
6、4B/5B编码
比特流中插入额外的比特以打破一连串的0或1,就是用5个比特来编码4个比特的数据,之后再传给接收方,因此称为4B/5B。编码效率为80%。
只采用16种对应16种不同的4位码,其他的16种作为控制码(帧的开始和结束,线路的状态信息等)或保留。
数字数据调制技术在发送端将数字信号转换为模拟信号,而在接收端将模拟信号还原为数字信号,分别对应于调制解调器的调制和解调过程。
调幅+调相(QAM)正交调幅调制!
计算机内部处理的是二进制数据,处理的都是数字音频,所以需要将模拟音频通过采样、量化转换成有限个数字表示的离散序列(即实现音频数字化)。
最典型的例子就是对音频信号进行编码的脉码调制(PCM),在计算机应用中,能够达到最高保真水平的就是PCM编码,被广泛用于素材保存及音乐欣赏,CD、DVD以及我们常见的WAV文件中均有应用,它主要包括三步:抽样、量化、编码
为了实现传输的有效性,可能需要较好的频率。这种调制方式还可以使用频分复用技术,充分利用带宽资源。在电话机和本地交换机所传输的信号是采用模拟信号传输模拟数据的方式;模拟的声音数据是加载到模拟的载波信号中传播的。
传输介质也称传输媒体/传输媒介,它就是数据传输系统中在发送设备和接收设备之间的物理通路。
传输媒体并不是物理层。传输媒体在物理层的下面,因为物理层是体系结构的第一层,因此有时称传输媒体为0层。在传输媒体中传输的是信号,但传输媒体并不知道所传输的信号代表什么意思。但物理层规定了电气特性,因此能够识别所传送的比特流。
双绞线是古老、又最常用的传输介质,它由两根采用一定规则并排绞合的、相互绝缘的铜导线组成。
绞合可以减少对相邻导线的电磁干扰。
为了进一步提高抗电磁干扰能力,可在双绞线的外面加上一个由金属丝编织成的屏蔽层,这就是屏蔽双绞线(STP),无屏蔽层的双绞线就称为非屏蔽双绞线(UTP)。
双绞线价格便宜,是最常用的传输介质之一,在局域网与传统电话网中普遍使用。模拟传输和数字传输都可以使用双绞线,其通信距离一般为几公里到数十公里。距离太远时,对于模拟传输,要用放大器放大衰减的信号;对于数字传输,要用中继器将失真的信号整形。
同轴电缆由导体铜质芯线、绝缘层、网状编制屏蔽层和塑料外层构成。按特性抗阻数值的不同,通常将同轴电缆分为两类:
同轴电缆VS双绞线
由于外导体屏蔽层的作用,同轴电缆抗干扰特性比双绞线好,被广泛用于传输较高速率的数据,其传输距离更远,但价格较双绞线贵。
光纤通信就是利用光导纤维传递光脉冲来进行通信。有光脉冲表示1,无光脉冲表示0。而可见光的频率大约是 10^8MHz,因此光纤通信系统的带宽远远大于目前其他各种传输介质的带宽。
光纤在发送端有光源,可以采用发光二极管或半导体激光器,它们在电脉冲作用下能产生出光脉冲;在接收端用光电二极管做成光检测器,在检测到光脉冲时可还原出电脉冲。
光纤主要由纤芯(实心的! )和包层构成,光波通过纤芯进行传导,包层较纤芯有较低的折射率。当光线从高折射率的介质射向低折射率的介质时,其折射角将大于入射角。因此,如果入射角足够大,就会出现全反射,即光线碰到包层时候就会折射回纤芯、这个过程不断重复,光也就沿着光纤传输下去。
特点:
包括无线电波,微波,红外线和激光等
诞生原因:由于存在损耗,在线路上传输的信号功率会逐渐衰减,衰减到一定程度时将造成信号失真,因此会导致接收错误。
中继器的功能:对信号进行再生和还原,对衰减的信号进行放大,保持与原数据相同,以增加信号传输的距离,延长网络的长度。
中继器的两端:两端的网络部分是网段,而不是子网,适用于完全相同的两类网络的互连,且两个网络速率要相同。
中继器只将任何电缆段上的数据发送到另一段电缆上,它仅作用于信号的电气部分,并不管数据中是否有错误或不适于网段的数据。
两端可连相同媒体,也可连不同媒体。
中继器两端的网段一定要是同一个协议。(中继器不会存储转发)
**5-4-3规则:**网络标准中都对信号的延迟范围作了具体的规定,因而中继器只能在规定的范围内进行,否则会网络故障。
又称为多口中继器
集线器的功能:对信号进行再生放大转发,对衰减的信号进行放大,接着转发到其他所有(除输入端口外)处于工作状态的端口上,以增加信号传输的距离,延长网络的长度。不具备信号的定向传送能力,是一个共享式设备。
结点:主机、路由器
链路:网络中两个结点之间的物理通道,链路的传输介质主要有双绞线、光纤和微波。分为有线链路、无线链路。
数据链路:网络中两个结点之间的逻辑通道,把实现控制数据传输协议的硬件和软件加到链路上就构成数据链路。
帧:链路层的协议数据单元,封装网络层数据报。
数据链路层负责通过一条链路从一个结点向另一个物理链路直接相连的相邻结点传送数据报。
(把网络层交付给它的数据报安全、无差错地传给相邻结点)
数据链路层在物理层提供服务的基础上向网络层提供服务,其最基本的服务是将源自网络层来的数据可靠地传输到相邻结点的目标网络层。其主要作用是加强物理层传输原始比特流的功能,将物理层提供的可能出错的物理连接改造成为逻辑上无差错的数据链路,使之对网络层标表现为一条无差错的链路。
封装成帧就是在一段数据的前后部分添加首部和尾部,这样就构成了一个帧。接收端在收到物理层上交的比特流后,就能根据首部和尾部的标记,从收到的比特流中识别帧的开始和结束。
首部和尾部包含许多的控制信息,她们的一个重要作用:帧定界(确定帧的界限)
帧同步:接收方应当能从接收到的二进制比特流中区分出帧的起始和终止。
组帧的四种方式:1、字符计数法 2、字符(节)填充法 3、零比特填充法 4、违规编码法
透明传输是指不管所传数据是什么样的比特组合,都应当能够在链路上传送。因此,链路层就“看不见”有什么妨碍数据传输的东西。
当所传数据中的比特组合恰巧与某-一个控制信息完全一样时, 就必须采取适当的措施,使收方不会将这样的数据误认为是某种控制信息。这样才能保证数据链路层的传输是透明的。
帧首部使用一个计数字段(第一个字节,八位)来标明帧内字符数。
目的结点的数据链路层收到字节计数值时,就知道后面跟随的字节数,从而确定帧结束位置。
问题:如果计数字段出错,即失去了帧边界划分的依据。
用特定字符来定界一帧的开始与结束。
控制字符EOH(Start of header)放在帧的最前面,表示帧的首部开始,控制字符EOT(End of transmission)表示帧的结束。为了使信息位中出现的特殊字符不被误判为帧的首尾定界符,可在特殊字符前面填充一个转义字符(ESC)来加以区分,以实现数据的透明传输。
零比特填充法使用一个特定的比特模式,即01111110来标志一帧的开始和结束。
为了不使信息位出现的比特流01111110被误判为帧的首尾标志,发送方的数据链路层在信息位中遇到5个连续的”1“时,将自动在其后插入一个”0“;
而接收方做该过程的逆操作,即每收到5个连续的”1“时,自动删除后面紧跟的”0“,以恢复原信息。
即 5 1 1 0
在物理层进行比特编码时,通常采用违规编码法。
曼彻斯特编码将数据比特”1“编码成”高-低“电平对,将数据比特”0“编码成”低-高“电平对,而”高-高“电平对和”低-低“电平对在数据比特中是违规的。可以借用这些违规编码序列来定界帧的起始和终止。
由于字节计数法中Count字段的脆弱性(其值若有差错将导致灾难性后果)及字符填充实现上的复杂性和不兼容性,目前普遍使用的帧同步法是比特填充和违规编码法。
传输中的差错都是噪声引起的。
全局性:由于线路本身电气特性所产生的随机噪声(热噪声),是信道固有的,随机存在的。
解决方法:提高信噪比来减少或避免干扰。
局部性:外界特定的短暂原因所造成的冲击噪声,是产生差错的主要原因。
解决方法:通常利用编码技术来解决。
差错
为什么要在数据链路层进行差错控制?
因为错误可以尽早发现,不会让一个错误的数据报发送了很长时间到达目的地之后才被发现,从而导致网络资源的浪费。
差错控制(比特错,帧错传输层讲解)
编码VS编码
数据链路层编码和物理层的数据编码与调制不同。物理层编码针对的是单个比特,解决传输过程中比特的同步等问题,如曼彻斯特编码。而数据链路层的编码针对的是一组比特,它通过冗余码的技术实现一组二进制比特串在传输过程是否出现了差错。
冗余编码
在数据发送之前,先按某种关系附加上一定的冗余位,构成一个符合某一规则的码字后再发送当要发送的有效数据变化时,相应的冗余位也随之变化,使码字遵从不变的规则。接收端根据收到码字是否仍符合原规则,从而判断是否出错。
奇偶校验码是奇校验码和偶校验码的统称,是一种最基本的校验码。
它由n-1位信息元和1位校验码组成。
它只能检测奇数位的出错情况,但并不知道哪些位错了,也不能发现偶数位的出错情况,检错能力百分之五十!
如下题:奇校验,添加一个校验位后为11100101,出现错误只能出现奇数个不一样的,因此出错后还是奇数个1则无法检测!
接收端检错过程
把收到的每一个帧都除以同样的除数,然后检查得到的余数R。
在数据链路层仅仅使用循环冗余检验CRC差错检测技术,只能做到对帧的无差错接收,即“凡是接收端数据链路层接受的帧,我们都能以非常接近于1的概率认为这些帧在传输过程中没有产生差错“。
接收端丢弃的帧虽然曾收到了,但是最终还是因为有差错被丢弃.“凡是接收端数据链路层接收的帧均无差错”。
可靠传输:数据链路层发送端发送什么,接收端就收到什么。
链路层使用CRC检验,能够实现无比特差错的传输,但这还不是可靠传输。
发现双比特错,纠正单比特错。
1)确定校验码位数 r
海明不等式:
以数据码 101101为例!
数据的位数 k = 6,满足不等式的最小 r 为 4。
也就是 D = 101101 的海明码应该有 6 + 4 = 10 位,
其中原数据 6 位,校验码 4 位。
2)确定校验码和数据的位置
假设这 4 位校验码分别为 P1,P2,P3,P4(放在2的几次方的位置);数据从左到右为 D1,D2,……,D6(按序把空填满)。
3)求出校验码的值
令所有要校验的位异或即可!
校验码二进制1的位置,数据码对应位置也为1时,进行异或!
P1⊕D1⊕D2⊕D4⊕D5 = 0 => P1 =0
P2⊕D1⊕D3⊕D4⊕D6 = 0 => P2 = 0
P3⊕D2⊕D3⊕D4 = 0 => P3 = 0
P4⊕D5⊕D6 = 0 => P4 = 1
故101101的海明码为 0010011101
4)检错并纠错
假设第五位出错,因此接收到的数据位是 0010111101。
令所有要校验的位异或运算。
P1⊕D1⊕D2⊕D4⊕D5 = 1
P2⊕D1⊕D3⊕D4⊕D6 = 0
P3⊕D2⊕D3⊕D4 = 1
P4⊕D5⊕D6 = 0
从P4往P1写:
二进制序列位0101,恰好对应十进制5,这样就找到了出错的位置,即出错位是第5位。
较高的发送速度和较低的接收能力的不匹配,会造成传输出错,因此需要流量控制。
数据链路层的流量控制是点对点的,而传输层的流量控制是端到端的。
数据链路层流量控制手段:接收方收不下就不回复确认。
传输层流量控制手段:接收方给发送方一个窗口公告。
流量控制的方法:
可靠传输:发送端发啥,接收端收啥。
流量控制:控制发送速率,使接收方有足够的缓冲空间来接收每一个帧。
滑动窗口解决
脑图
为什么要有停等协议?
因为在链路上出了比特出差错外,底层的信道还会出现丢包问题。
丢包:物理线路故障,设备故障,病毒攻击,路由信息错误等原因,会导致数据包的丢失。
这里的数据包就是一个数据,在不同层次有不同的名字;在链路层是帧,在网络层是数据报/分组,在传输层是报文段。
研究停等协议的前提?
虽然现在常用全双工通信方式,但为了讨论问题方便,仅考虑一方发送数据(发送方),一方接收数据(接收方))。
因为是在讨论可靠传输的原理,所以并不考虑数据是在哪一个层次上传送的。
“停止-等待”就是每发送完一个分组就停止发送,等待对方确认,在收到确认后再发送下一个分组。
无差错接收与可靠传输的区别
无差错接收是指–凡是接收的帧(不包括丢弃的帧),我们都能以非常接近于1的概率认为这些帧在传输过程中没有产生差错–。也就是说:凡是接收端数据链路层接受的帧都没有传输差错(有差错的帧就丢弃而不接受)。
要做到可靠传输(即发送什么就收到什么)就必须加上确认和重传机制。
停止等待协议
1)无差错情况
2.1)数据帧丢失或检测到帧出错
2.2)ACK丢失
2.3)ACK迟到
性能分析
信道利用率
停止等待协议弊端
停等协议发送方每发送一个帧就处于等待状态,等到接收方回复一个确认帧,发送方才会发送新的帧。因此大部分时间都是在等待,真正发送数据的时间很少,极大地浪费了资源。
为了解决这个问题,可以采用流水线技术,一次发送多个帧,但同时在其他方面需要改进:
针对这种解决方案,就推出了GBN和SR。
脑图
发送窗口:发送方维持一组连续的允许发送的帧的序号。
接收窗口:接收方维持一组连续的允许接收帧的序号。
发送方必须响应的三件事
1、上层的调用
上层要发送数据时,发送方先检查发送窗口是否已满,如果未满,则产生一个帧并将其发送;如果窗口已满,发送方只需将数据返回给上层,暗示上层窗口已满。上层等一会再发送。
2、收到了一个ACK
GBN协议中,对n号帧的确认采用累积确认的方式,标明接收方已经收到n号帧和它之前的全部帧。
3、超时事件
如果出现超时,发送方重传所有已发送但未被确认的帧。
接收方要做的事
如果正确收到n号帧,并且按序,那么接收方为n帧发送一个ACK,并将该帧中的数据部分交付给上层。
其余情况都丢弃帧,并为最近按序接收的帧重新发送ACK。接收方无需缓存任何失序帧,只需要维护一个信息:expectedseqnum(下一个按序接收的帧序号)。
运行中的GBN
滑动窗口长度
若采用n个比特对帧编号,那么发送窗口的尺寸Wt应满足:
因为发送窗口尺寸过大,就会使得接收方无法区分新帧和旧帧。
GBN协议重点总结
GBN协议性能分析
脑图
SR协议
发送方必须响应的三件事
1、上层的调用
从上层收到数据后,SR发送方检查下一个可用于该帧的序号,如果序号位于发送窗口内,则发送数据帧;否则就像GBN一样,要么将数据缓存,要么返回给上层之后再传输。
2、收到了一个ACK
如果收到ACK,假如该帧序号在窗口内,则SR发送方将那个被确认的帧标记为已接收。如果该帧序号是窗口的下界(最左边第一个窗口对应的序号),则窗口向前移动到具有最小序号的未确认帧处。如果窗口移动了并且有序号在窗口内的未发送帧,则发送这些帧。
3、超时事件
每个帧都有自己的定时器,一个超时事件发生后只重传一个帧。
SR接收方要做的事
来者不拒(窗口内的帧)
SR接收方将确认一个正确接收的帧而不管其是否按序。失序的帧将被缓存,并返回给发送方一个该帧的确认帧【收谁确认谁】,直到所有帧(即序号更小的帧)皆被收到为止,这时才可以将一批帧按序交付给上层,然后向前移动滑动窗口。
如果收到了窗口序号外(小于窗口下界(指的是当前滑动窗口相邻的上一个滑动窗口))的帧(说明上一次返回的ACK丢失了),就返回一个ACK。其他情况,就忽略该帧。
运行中的SR
滑动窗口长度
发送窗口最好等于接收窗口。(大了会溢出,小了没意义)
这里的 n 是 log(序号最大值+1)
大于2^(n-1)时,仍会产生无法区分新旧帧的问题!
SR协议重点总结
点对点链路:两个相邻节点通过一个链路相连,没有第三者。
应用:PPP协议,常用于广域网。
广播式链路:所有主机共享通信介质。
应用:早期的总线以太网、无线局域网,常用于局域网。
典型拓扑结构:总线型、星型(逻辑总线型)
采取一定的措施,使得两对节点之间的通信不会发生互相干扰的情况。
静态划分信道:信道划分介质访问控制
动态分配信道
信道划分介质访问控制(MAC Multiple Access Control )协议:
随机访问MAC协议:唯一会产生冲突
轮询访问MAC协议/轮流协议/轮转访问MAC协议:
将使用介质的每个设备与来自同一信道上的其他设备的通信隔离开,把时域和频域合理地分配给网络上的设备。
信道划分的实质就是通过分时、分频、分码等方法把原来的一条广播信道,逻辑上分为几条用于两个结点之间通信的互不干扰的子信道,实际上就是把广播信道转变为点对点信道。
多路复用技术:把多个信号组合在一条物理信道上进行传输,使得多个计算机或终端设备共享信道资源,提高信道利用率。
采用多路复用技术可以把多个输入通道的信息整合到一个复用通道中,在接收端把收到的信息分离出来并传送到对应的输出通道。
频分多路复用FDM
用户在分配到一定的频带后,在通信过程中自始至终都占用这个频带。频分复用的所有用户在同样的时间占用不同带宽(频率带宽)资源。
时分多路复用TDM
将时间划分为一段段等长的时分复用帧(TDM帧)。每一个时分复用的用户在每一个TDM帧中占用固定序号的时隙,所有用户轮流占用信道。
TDM帧是在物理层传送的比特流所划分的帧,标志一个周期。
改进的时分复用-统计时分复用STDM
波分多路复用WDM
利用光的频分多路复用,在一根光纤中传输多种不同波长的光信号,由于波长(频率)不同,所以各路光信号互不干扰,最后再用波长分解复用器将各路波长分解出来。
码分多路复用CDM
码分多址(CDMA)[Code Division Multiple Access] 是码分复用的一种方式。
1个比特分为多个码片/芯片(chip),每个站点被指定一个唯一的 m 位的芯片序列。
发送1时站点发送芯片序列,发送0时发送芯片序列反码(通常把0写成1)。
如何不打架:多个站点同时发送数据的时候,要求各个站点的芯片序列相互正交。
如何合并:各路数据在信道中被线性相加。
如何分离:合并的数据和源站规格化内积。
动态分配信道:动态媒体接入控制/多点接入
特点:信道并非在用户通信时固定分配给用户。
随机访问介质访问控制:所有用户可随机发送信息。发送信息时占全部带宽。
不协调 -> 冲突
ALOHA协议
纯ALOHA协议
协议思想:当网络中的任何一个站点需要发送数据时,可以不监听信道,不按时间槽发送,随机重发。想发就发。
如果在一段时间内未收到确认,那么该站点就认为传输过程中发生了冲突。
发送站点需要随机等待一段时间后再发送数据,直至发送成功。
冲突如何检测?
如果发生冲突,接收方在就会检测出差错,然后不予确认,发送方在一定时间内收不到确认就判断发生冲突。
冲突如何解决?
超时后等一随机时间再重传。
时隙ALOHA协议
协议思想:把时间分成若干个相同的时间片,所有用户在时间片开始时刻同步接入网络信道,若发生冲突,则必须等到下一个时间片开始时刻再发送。
控制想发就发的随意性。
两者比较
载波监听多路访问协议CSMA(carrier sense multiple access)
CS:载波监听,每个站在发送数据之前要检测一下总线上是否有其他计算机在发送数据。
当几个站同时在总线上发送数据时,总线上的信号电压摆动值将会增大( 互相叠加)。当一个站检测到的信号电压摆动值超过一定门限值时, 就认为总线上至少有两个站同时在发送数据,表明产生了碰撞,即发生了冲突。
MA:多点接入,表示许多计算机以多点接入的方式连接在一根总线上。
协议思想:发送帧之前,监听信道。
监听结果
1-坚持CSMA
坚持指的是对于监听信道忙之后的坚持。
思想:如果一个主机要发送信息,那么它先监听信道。
优点:只要媒体空闲,站点就马上发送,避免了媒体利用率的损失。
缺点:假如有两个或两个以上的站点有数据要发送,冲突就不可避免。
非坚持CSMA
非坚持指的是对于监听信道忙之后就不继续监听。
思想:如果一个主机要发送信息,那么它先监听信道。
优点:采用随机的重发延迟时间可以减少冲突发生的可能性。
缺点:可能存在大家都在延迟等待过程中,使得媒体仍可能处于空闲状态,媒体使用率低。
p-坚持CSMA
p-坚持指的是对于监听信道空闲的处理。
p-坚持CSMA思想:如果一个主机要发送消息,那么它先监听信道。
优点:既能像非坚持算法那样减少冲突,又能像1-坚持算法那样减少媒体空闲时间。
缺点:发生冲突后还是要坚持把数据帧发送完,造成了浪费。
三种CSMA协议对比
脑图
载波监听/多路访问/碰撞检测 CSMA/CD(carrier sense multiple access with collision detection)
CS:载波监听,每个站在发送数据之前以及发送数据时要检测一下总线上是否有其他计算机在发送数据。
MA:多点接入,表示许多计算机以多点接入的方式连接在一根总线上。 总线型网络。
CD:碰撞检测(冲突检测):“边发送边监听”,适配器边发送数据边检测信道上信号电压的变化情况,以便判断自己在发送数据时其他站是否也在发送数据。半双工网络。
先听后发为什么还有冲突?
因为电磁波在总线上总是以有限速率传播的!
传播时延对载波监听的影响?
最迟多久才能直到自己发送的数据没和别人碰撞 ?
最多时两倍的总线端到端的传播时延 2τ(争用期/冲突窗口/碰撞窗口)
只要经过 2τ 时间还没有检测到碰撞,就能肯定这次发送不会发生碰撞。
如何确定碰撞后的重传时机 ?
截断二进制指数规避算法
1、确定基本退避(推迟)时间为争用期2τ。
2、定义参数k,它等于重传次数,但k不超过10,即k=min[重传次数,10]。当重传次数不超过10时,k等于重传次数;当重传次数大于10时,k就不再增大而一直等于10。
3、从离散的整数集合[0, 1, (2^k) - 1]中随机取出一个数r,重传所需要退避的时间是r倍的基本退避时间,即2r τ。
4、当重传达16次仍不能成功,说明网络太拥挤,认为此帧永远无法正确发出,抛弃此帧并向高层报告出错。
例子
若连续多次发生冲突,就表明可能有较多的站参与争用信道。使用此算法可使重传需要推迟的平均时间随重传次数的增大而增大,因而减小发生碰撞的概率,有利于整个系统的稳定
最小帧长问题
如果发送了一个很小的帧发生了碰撞,但是由于帧太短,帧发送完毕之后才能检测到发生了碰撞,已经没有办法停止发送。因此定义了最小帧长,希望在检测到碰撞的时候,帧还没发送结束。
帧的传输时延至少要两倍于信号在总线中的传播时延。
最小帧长=总线传播时延 x 数据传输速率 x 2
以太网规定最短帧长为64B,凡是长度小于64B的都是由于冲突而异常终止的无效帧。
载波监听多路访问/碰撞避免 CSMA/CA (carrier sense multiple access with collision avoidance)
为什么要有CA协议?
工作原理:发送数据前,先检测信道是否空闲。
CSMA/CD 与 CSMA/CA
相同点:
CSMA/CD 与 CSMA/CA 机制都从属于 CSMA的思路,其核心是 先听再说,接入信道之前必须要进行监听。当发现信道空闲时,才能进行接入。
不同点:
轮询访问
轮询协议
主节点轮流 “邀请” 从属结点发送数据。
优点:不会发生冲突,每次只能允许一台主机发送数据,该主机占用全部带宽。
缺点:询问的过程就是发送一个较短的数据帧,如果从属结点较多,就会多次轮询,产生较大的开销,对于靠后的主机,会有等待延迟,等待前面的主机轮询结束
令牌传递协议
主要用在令牌环局域网中。
令牌:一个特殊格式的MAC控制帧,不含任何信息。控制信道的使用,确保同一时刻只有一个结点独占信道。
每个结点都可以在一定的时间内(令牌持有时间)获得发送数据的权利,并不是无限制地持有令牌。
问题:
应用于令牌环网(物理星型拓扑,逻辑环形拓扑)。
当计算机都不需要发送数据时,令牌就在环形网上游荡,而需要发送数据的计算机只有在拿到该令牌后才能发送数据帧,因此不会发生冲突。
采用令牌传送方式的网络常用于负载较重、通信量较大的网络中。
脑图
局域网 (Local Area Network):简称LAN,是指在某一区域内多台计算机互联成的计算机组,使用广播信道。
决定局域网的主要要素为:网络拓扑,传输介质与介质访问控制方法。
局域网拓扑结构
介质访问控制方法
CSMA/CD:常用于总线型局域网,也用于树型网络
令牌总线:常用于总线型局域网,也用于树型网络
令牌环:用于环形局域网,如令牌环网。
局域网传输介质
局域网分类
IEEE 802标准
IEEE802系列标准是IEEE802LAN/MAN标准委员会制定的局域网、城域网技术标准(1980年2月成立)。其中最广泛使用的有以太网、令牌环、无线局域网等。这一系列标准中的每一个子标准都由委员会中的一个专门工作组负责。
FDDI:802.8
MAC子层和LLC子层
IEEE 802标准所描述的局域网参考模型只对应OSI参考模型的数据链路层与物理层,它将数据链路层划分为逻辑链路层LLC子层和介质访问控制MAC子层。
脑图
以太网(Ethernet)指的是由Xerox公司创建并由Xerox、Intel和DEC公司联合开发的基带总线局域网规范,是当今现有局域网采用的最通用的通信协议标准。以太网络使用CSMA/CD(载波监听多点接入/冲突检测)技术。
又叫做802.3局域网!
以太网在局域网各种技术中占统治性地位:
以太网两个标准
以太网提供无连接、不可靠的服务
以太网只实现无差错接收,不实现可靠传输。
以太网传输介质与拓扑结构的发展
粗同轴电缆 -> 细同轴电缆 -> 双绞线+集线器
使用集线器的以太网在逻辑上仍是一个总线网,
各站共享逻辑上的总线,使用的还是CSMA/CD协议。
以太网拓扑:逻辑上总线型,物理上星型。
10BASE-T以太网
10BASE-T是传送基带信号的双绞线以太网,T表示采用双绞线,现10BASE-T采用的是无屏蔽双绞线(UTP),传输速率是10Mb/s。
物理上采用星型拓扑,逻辑上总线型,每段双绞线最长为100m。
采用曼彻斯特编码。
采用CSMA/CD介质访问控制。
适配器与MAC地址
计算机与外界有局域网的连接是通过通信适配器的。
通信适配器:
网络接口板
网络接口卡NIC(network interface card)
现在,不再使用单独网卡。
适配器上装有处理器和存储器(包括RAM和ROM)。
ROM上有计算机硬件地址MAC地址。
在局域网中,硬件地址又称为物理地址,或MAC地址。
MAC地址:每个适配器有一个全球唯一的48位二进制地址,前24位代表厂家(由IEEE规定),后24位厂家自己指定。常用6个十六进制数表示。02-60-8c-e4-b1-21
以太网MAC帧
最常用的MAC帧是以太网V2的格式。
与IEEE 802.3的区别:
数据部分的最小字节为46,因为CSMA/CD协议最小帧长64B,因此剩下的就是64-6-6-2-4=46B.
前导码七个字节的101…用于数据同步,最后一个字节…11用于表示结束。
FCS:CRC循环冗余检验的4个字节的帧检验序列
数据链路层加头加尾,有帧开始定界符,为啥没有帧结束定界符?
以太网使用曼彻斯特编码,一个比特内都有两个码元,帧结束时候电压就不会变了,轻松确认帧结束位置,往前4B进而得到数据结束位置!
每两个帧发送都会有一个间隔!间隔中是不会有电压变化的!
高速以太网
速率>=100Mb/s的以太网称为高速以太网。
1、100BASE-T以太网
在双绞线上传送100Mb/s基带信号的星型拓扑以太网,仍使用IEEE802.3的CSMA/CD协议。
支持全双工和半双工,可在全双工方式下工作而无冲突。
2、吉比特以太网
在光纤或双绞线上传送1Gb/s信号。
支持全双工和半双工,可在全双工方式下工作而冲突。
3、10吉比特
10吉比特以太网在光纤上传送10Gb/s信号。
IEEE 802.11 是无线局域网通用的标准,它是由IEEE所定义的无线网络通信的标准。
和WIFI的区别 ?
无线局域网的覆盖范围比WIFI大得多;
WIFI是802.11b和802.11g所定义的标准,满足这两个标准属于WIFI。
802.11的MAC帧头格式
例如:AB两个设备和分别对应的两个基站AP1,AP2.
则接收端就是mac(AP2),发送端就是mac(AP1),目的地址mac(B),源地址mac(A)
无线局域网的分类
有固定基础设施无线局域网
服务集标识符:例如WiFi的名字
无固定基础设施无线局域网的自组织网络
广域网(WAN,Wide Area Network),通常跨越很大的物理范围,所覆盖的范围从几十公里到几千公里,它能连接多个城市或国家,或横跨几个洲并能提供远距离通信,形成国际性的远程网络。
广域网的通信子网主要使用分组交换技术。广域网的通信子网可以利用公用分组交换网、卫星通信网和无线分组交换网,它将分布在不同地区的局域网计算机系统互连起来,达到资源共享的目的。如因特网(Internet)是世界上范围最大的广域网。
广域网VS局域网
点对点协议PPP(Point-to-Point Protocol)是使用串行线路通信的面向字节的协议,该协议应用在直接连接两个结点的链路上。
设计的目的主要是用来通过拨号或专线方式建立点对点连接发送数据,使其成为各种主机、网桥和路由器之间简单连接的一种共同的解决方案。是目前使用最广泛的数据链路层协议。
只支持全双工链路。
PPP协议应满足的要求
PPP协议无需满足的要求
PPP协议的三个组成部分
1、链路控制协议(LCP):一种扩展链路控制协议,用于建立、配置、测试和管理数据链路。(身份验证)
2、网络控制协议(NCP):PPP协议允许同时采用多种网络层协议,每个不同的网络层协议要用一个相应的NCP来配置,为网络层协议建立和配置逻辑连接。
3、一个将IP数据报封装到串行链路的方法(同步串行/异步串行):IP数据报在PPP帧中就是其信息部分,这个信息部分的长度受最大传送单元(MTU)的限制。
PPP协议状态图
PPP协议的帧格式
高级数据链路控制(HDLC,High-Level Data Link Control),是一个在同步网上传输数据、面向比特的数据链路层协议,它是由国际标准化组织(ISO)根据IBM公司的SDLC(Synchronous Data Link Control)协议扩展开发而成的。
特点:
HDLC的站
三种数据操作方式:
HDLC的帧格式
总结:无奸细
PPP协议 VS HDLC协议
设备和集线器之间距离最大100m,否则会严失帧!
冲突域发生冲突概率太高了!
两个或多个以太网通过网桥连接后,就成为一个覆盖范围更大的以太网,而原来的每个以太网就称为一个网段。网桥工作在链路层的MAC子层,可以使以太网各网段成为隔离开的碰撞域。
网桥根据MAC帧的目的地址对帧进行转发和过滤。当网桥收到一个帧时,并不向所有接口转发此帧,而是先检查此帧的目的MAC地址,然后再确定将该帧转发到哪一个接口,或者是把它丢弃(即过滤)。
网段:一般指一个计算机网络中使用同一物理层设备(传输介质、中继器、集线器等)能够直接通讯的那一部分。
如果把网桥换成工作在物理层的转发器,那么就没有这种过滤通信量的功能。
由于各网段相对独立,因此一个网段的故障不会影响到另一个网段的运行。
网桥优点:
透明网桥
”透明“ 指以太网上的站点并不知道所发送的帧将经过哪几个网桥,是一种即插即用设备 —— 自学习。
通过自学习来构建转发表。每一个通过网桥的数据包都会被记录下网桥收到数据时数据对应的地址和网桥自己的接口,通过许许多多的数据包构造的缓存,网桥就可以知道哪个数据包在哪个接口,以后如果要穿数据包就知道要往哪个接口发送数据包了。
源路由网桥
在发送帧时,把详细的最佳路由信息(路由最少/时间最短)放在帧的首部中。
选择的是最佳路由。
方法:源站以广播方式向欲通信的目的站发送一个发现帧。
通过广播方式向目标地址发送广播,此时可能会经过不同路由产生不同的路径,目标地址收到后再将每一条路径都发一个响应帧给网桥,网桥经过对比就知道哪个接口最快。
以太网交换机
以太网交换机本质上是一个多端口的网桥,它工作在数据链路层。交换机能经济地将网络分成小的冲突域,为每个工作站提供更高的带宽。
以太网交换机的两种方式:
冲突域VS广播域
冲突域:在同一个冲突域中的每一个结点都能收到所有被发送的帧。简单的说就是同一时间内只能有一台设备发送信息的范围。
广播域:网络中能接收任一设备发出的广播帧的所有设备的集合。简单的说如果站点发出一个广播信号,所有能接收到这个信号的设备的范围称为一个广播域。
主要任务是把分组从源端传到目的端,为分组交换网上的不同主机提供通信服务。网络层传输单位是数据报。
分组&数据报:父与子关系!
例子:电话
在进行数据传输时,两个结点之间必须先建立一条专用(双方独占)的物理通信路径(由通信双方之间的交换设备和链路逐段连接而成),该路径可能经过许多中间结点。这一路径在整个数据传输期间一直被独占,直到通信结束后才被释放。
电路交换的阶段:建立连接、数据传输、释放连接。
电路交换的关键点是,在数据传输的过程中,用户始终占用端到端的固定传输带宽。
电路交换技术的优点:
电路交换的缺点:
数据交换的单位是报文,报文携带有目标地址、源地址等信息。
报文交换在交换结点采用的是存储转发的传输方式。
报文交换的优点:
报文交换的缺点:
同报文交换一样,分组交换也采用存储转发方式,但解决了报文交换中大报文传输的问题。
分组交换限制了每次传送的数据块大小的上限,把大的数据块划分为合理的小数据块,在加上一些必要的控制信息(如源地址、目的地址和编号信息等),构成分组。
分组交换的优点:
分组交换的缺点:
例子
传播延迟忽略!
报文交换:发送时延10s,第一个交换机发出也要10s,第二个也要10s,第二个交换机到目的站点忽略不计,总共30s.
分组交换:10000bit,每个分组10bit,共有1000个分组,由于分组是并行转发方式,因此只需要计算全部分组发送的时间再加上最后一个分组用掉的时延即可,即1000 * 0.01 + 0.01 * 2 = 10.02s
注意点
计算题中要注意的几点:
数据报方式为网络层提供无连接服务。
虚电路方式为网络层提供连接服务。
无连接服务:不事先为分组的传输确定传输路径,每个分组独立确定传输路径,不同分组传输路径可能不同。
连接服务:首先为分组的传输确定传输路径(建立连接),然后沿该路径(连接)传输系列分组,系列分组传输路径相同,传输结束后拆除连接。
虚电路将数据报方式和电路交换方式结合,以发挥两者优点。
虚电路:一条源主机到目的主机类似于电路的路径(逻辑连接),路径上所有结点都要维持这条虚电路的建立,都维持一张虚电路表,每一项记录了一个打开的虚电路的信息。
数据报VS虚电路
固定部分20B
1)版本:指IP的版本,IPv4 / IPv6
2)首部长度:占4位,单位是4B。可以表示的最大十进制数是15。以32位为单位,最大值为60B(15x4B)。最常用的首部长度是20B。
3)区分服务:指示期望获得哪种类型的服务。
4)总长度:占16位,首部 + 数据,单位是 1B。数据报的最大长度位 2^16 - 1 = 65535B。以太网帧的最大传送单元(MTU)位1500B,因此当一个IP数据报封装成帧时,数据报的总长度一定不能超过下面的数据链路层的MTU值。
5)标识:占16位。它时一个计数器,每产生一个数据报就加1,并赋值给标识字段。当一个数据报的长度超过网络的MTU时,必须分片,此时每个数据报片都复制一次标识号,以便能正确重装成原来的数据报。同一数据报的分片使用同一标识。
6)标志:占3位。xxx,最高位无意义,标志字段的最低位 MF,MF = 1 表示后面还有分片,MF = 0 表示最后一个分片或没有分片。标志字段中间的一位时 DF,只有当 DF = 1 时才允许分片。
7)片偏移:占13位。它指出较长的分组在分片后,某片在原分组中的相对位置。片偏移以8个字节为偏移单位,即每个分片的长度一定是8B(64位)的整数倍。(除了最后一个分片,每个分片的长度一定是8B的整数倍)
8)生存时间(TTL):占8位。数据报在网络中可通过的路由器数的最大值,标识分组在网络中的寿命,以确保分组不会永远在网络中循环。经过一个路由器 -1,变成 0 则丢弃。
9)协议:占8位。指出此分组携带的数据使用何种协议,即分组的数据部分应交给哪个传输层协议,如TCP、UDP等。其中值为6表示TCP,值为17表示UDP。
10)首部校验和:占16位。IP数据报的首部校验和只校验分组的首部,而不校验数据部分。
11)源地址字段:占32位,标识发送方的IP地址。
12)目的地址字段:占32位,标识接收方的IP地址。
13)可选字段:0~40B,用来支持排错、测量以及安全等措施。
14)填充:全0,把首部补成4B的整数倍。
三个单位
速记:一种八片的首饰
片偏移例子
一个数据链路层数据报能承载的最大数据量称为最大传送单元(MTU)。因为IP数据报被封装在数据链路层数据报中,因此数据链路层的MTU严格地限制着 IP 数据报的长度。
分片:当IP数据报的总长度大于链路MTU时,就需要将IP数据报中的数据分装在两个或多个较小的IP数据报中,这些较小的数据报称为片。
IP地址:全世界唯一的32位/4字节标识符,标识路由器主机的接口。
IP地址:= {<网络号>,<主机号>}
网络号标志主机(或路由器)所连接到的网络。主机号标志着该主机(或路由器)。
对于A类,最大可用网络数除了要减去全0表示的本网络,还有减去全1时候表示的127,即本地环回地址!
最大主机数都要减去全0和全1表示的本网络和广播地址!
在各类IP地址中,有些IIP地址具有特殊用途,不用做主机的IP地址:
路由器对目的地址是私有IP地址的数据报一律不进行转发。
采用私有IP地址的互联网络称为专用互联网或本地互联网。
**网络地址转换(NAT)**是指通过将专用网络地址转换为公用地址,从而对外隐藏内部管理的IP地址。它使得整个专用网只需要一个全球IP地址就可以与因特网连通,由于专用网本地IP地址是可重用的,所以NAT大大节省了IP地址的消耗。
私有IP地址只用于LAN,不用于WAN连接(因此私有IP地址不能直接用于Internet,必须通过网关利用NAT把私有IP地址转换为Internet中合法的全球IP地址后才能用于Internet),并且允许私有IP地址被LAN重复使用。这有效地解决了IP地址不足的问题。
使用NAT时需要在专用网连接到因特网的路由器上安装NAT软件,NAT路由器至少有一个有效的外部全球地址。使用本地地址的主机和外界通信时,NAT路由器使用NAT转换表将本地地址转换成全球地址,或将全球地址转换成本地地址。NAT转换表中存放着**{本地IP地址:端口} 到{全球IP地址:端口}**的映射。通过{ip地址:端口}这样的映射方式,可让多个私有IP地址映射到同一个全球IP地址。
分类的IP地址的弱点:
子网划分:在IP地址中增加一个子网号字段,使两级IP地址变成了三级IP地址。
基本思路
子网掩码是一个与IP地址相对应的、长32bit的二进制串,它由一串1和跟随的一串0组成。
其中,1对应于IP地址中的网络号及子网号,而0对应于主机号。
计算机只需将IP地址和其对应的子网掩码逐位“与”(逻辑AND运算),就可得出相应子网的网络地址。
例子一
例子二
路由表中:
使用子网掩码时路由器的分组转发算法
无分类域间路由选择是在变长子网掩码的基础上提出的一种消除传统 A、B、C类网络划分,并且可以在软件的支持下实现超网构造的一种IP地址的划分方法。
IP地址的无分类两级编址为:IP:: = {<网络前缀>, <主机号>}
斜线记法:IP地址/网络前缀所占比特数
其中,网络前缀所占比特数对应于网络号的部分,等效于子网掩码中连续1的部分。
将多个子网聚合成一个较大的子网,叫做构成超网,或路由聚合。
方法:将网络前缀缩短。
CIDR地址块中的地址数一定是2的整数次幂,实际可指派的地址数通常为 2^N - 2,N 表示主机号的位数,主机号全0代表网络号,主机号全1为广播地址。
转成二进制,上下对其,相同的位数就是网络前缀数!
使用CIDR时,路由表中的每个项目由“网络前缀”和“下一跳地址”组成。查找路由表可能得到几个匹配结果,应选择具有最长网络前缀的路由。前缀越长,地址块越小,路由越具体
IP地址是网络层使用的地址,它是分层次等级的。硬件地址是数据链路层使用的地址(如MAC地址),它是平面式的。在网络层及网络层之上使用IP地址,IP地址放在IP数据报的首部,而MAC地址放在MAC帧的首部。通过数据封装,把IP数据报分组封装为MAC帧后,数据链路层看不见数据报分组中的IP地址。
在实际网络的链路上传送数据帧时,最终必须使用硬件地址。
APR协议:完成主机或路由器IP地址到MAC地址的映射。(解决下一条走哪的问题)
ARP协议使用了IP地址和MAC地址,属于网络层和链路层的协议,两层协议,但一般将其归为网络层协议,在TCP/IP协议栈中处于网络层IP的最左下角接近链路层的位置!
检查ARP高速缓存,有对应表项则写入MAC帧,没有则用目的MAC地址为FF-FF-FF-FF-FF-FF的帧封装并广播ARP请求分组,同一局域网中所有主机都能收到该请求。目的主机收到请求后就会向源主机单播一个ARP响应分组,源主机收到后将此映射写入ARP缓存(10-20min更新一次)。
ARP高速缓存里面保存的是一个局域网内的隐射!
例子
源IP和目的IP不变,变得都是源和目的MAC地址,一层层找下去!
从IP地址到硬件地址的解析是自动进行的,主机的用户并不知道这种地址解析过程。只要主机或路由器和本网络上的另一个已知IP地址的主机或路由器进行通信,ARP就会自动地将这个IP地址解析为数据链路层所需要的硬件地址。
动态主机配置协议(Dynamic Host Configuration Protocol)常用于给主机动态地分配IP地址。
DHCP是应用层协议,使用客户/服务器方式,客户端和服务端通过广播方式进行交互,基于UDP。
DHCP提供即插即用联网的机制,主机可以从服务器动态获取IP地址、子网掩码、默认网关、DNS服务器名称与iP地址,允许地址重用,支持移动用户加入网络,支持在用地址续租。
主机获取IP地址:
需要IP地址的主机在启动时就向DHCP服务器广播发现报文,这时该主机就成为DHCP客户。本地网络上所有主机都能收到此广播报文,但只有DHCP服务器才回答此报文。DHCP服务器先在其数据库中查找该计算机的配置信息。若找到,则返回找到的信息。若找不到,则从服务器的IP地址池中取一个地址分配给高计算机。DHCP服务器的回答报文称为提供报文。
DHCP服务器聚合DHCP客户端的交换过程:
1、DHCP客户机广播”DHCP发现“信息,试图找到网络中的DHCP服务器,以便从DHCP服务器获得一个IP地址。
2、DHCP服务器收到”DHCP发现“消息后,向网络中广播”DHCP提供“消息,其中包括提供DHCP客户机的IP地址和相关配置信息。
3、DHCP客户机收到”DHCP提供“消息,如果接收DHCP服务器所提供的相关参数,那么通过广播”DHCP请求“消息向DHCP服务器请求提供IP地址。
4、DHCP服务器广播“DHCP确认”消息,将IP地址分配给DHCP客户机。
DHCP允许网络上配置多台DHCP服务器,当DHCP客户机发出DHCP请求后,有可能收到多个应答消息,这时DHCP客户机通常挑选最先到达的。
DHCP服务器分配给DHCP客户的IP地址是临时的,因此DHCP客户只能在一段有限时间内使用这个分配到的IP地址。DHCP称这段时间为租用期。租用期的数值应由DHCP服务器自己决定,DHCP客户也可以在自己发送的报文中提出对租用期的要求。
采用广播方式进行交互的原因是在DHCP执行初期,客户端不知道服务器端的IP地址,而在执行中间,客户端并未分配IP地址,从而导致两者之间的通信必须采用广播方式。采用UDP而不采用TCP的原因也很明显:TCP需要建立连接,如果连对方的IP地址都不知道,那么更不可能通过双方的套接字建立连接。
为了提高IP数据报交付成功的机会,在网络层使用了网际控制报文协议(Internet Control Message Protocol,ICMP)来让主机或路由器报告差错和异常情况。ICMP报文作为IP层数据报的数据,加上数据报的首部,组成IP数据报发送出去。ICMP是IP层协议。
ICMP报文分为 ICMP差错报告报文 和 ICMP询问报文。
ICMP差错报告报文用于目标主机或到目标主机路径上的路由器向源主机报告差错和异常情况。共5种类型。
ICMP差错报告报文数据字段
不应发送ICMP差错报告报文的几种情况:
ICMP询问报文有4种类型:
主要应用
PING:用来测试两台主机之间的连通性。使用了ICMP回送请求和回答报文。工作在应用层。
Trancerout/Tracert:用来跟踪分组经过的路由。使用了ICMP时间超过报文。工作在网络层。
解决“IP地址耗尽”问题的措施有以下三种:
改进首部格式:快速处理/转发数据报
支持QoS
Qos ( Quality of Service,服务质量)指一个网络能够利用各种基础技术,为指定的网络通信提供更好的服务能力,是网络的一种安全机制,是用来解决网络延迟和阻塞等问题的一种技术。
一般形式冒号十六进制记法:4BF5:AA12:0216:FEBC:BA5F:039A:BE9A:2170
压缩形式:4BF5:0000:0000:0000:BA5F:039A:000A:2176 -> 4BF5:0:0:0:BA5F:39A:A:2176。
零压缩:一连串连续的0可以被一对冒号取代。
FF05:0:0:0:0:0:0:B3 -> FF05:B3
双冒号表示法在一个地址中仅可出现一次。
双栈协议:在一台设备上同时装有IPv4和IPv6协议栈,那么这台设备既能和IPv4网络通信,又能和IPv6网络通信。如果这台设备是一个路由器,那么在路由器的不同接口上分别配置了IPv4地址和IPv6地址,并很可能分别连接了IPv4网络和IPv6网络;如果这台设备是一台计算机,那么它将同时拥有IPv4地址和IPv6地址,并且具备同时处理这两个协议地址的功能。
隧道技术:将整个IPv6数据报封装到IPv4数据报的数据部分,使得IPv6数据报可以在IPv4网络的隧道中传输。重新封装
路由算法
自治系统(Autonomous System,AS):单一技术管理下的一组路由器,这些路由器使用一种AS内部的路由选择协议和共同的度量来确定分组在该AS内的路由,同时还使用一种AS之间的路由选择协议来确定分组在AS之间的选择。
一个自治系统内的所有网络都由一个行政单位(如一家公司、一所大学、一个政府部门等)管辖,一个自治系统的所有路由器在本自治系统内都必须是连通的。
因特网把路由选择协议划分为两大类:
脑图
路由信息协议(Routing Information Protocol,RIP)是内部网关协议(IGP)中最先得到广泛应用的协议。
RIP是一种分布式的基于距离向量的路由选择协议,其最大的优点就是简单。
RIP协议是应用层协议,使用UDP传送数据!(端口520)。RIP选择的路径不一定是时间最短的,但一定是具有最少路由器的路径。因为它是根据最少跳数进行路径选择的。
RIP规定
RIP协议和谁交换?
仅和相邻路由器交换信息。
多久交换一次?
每30秒交换一次路由信息,然后路由器根据新信息更新路由表。若超过180s没收到邻居路由器的通告,则判定邻居没了,并更新自己路由表。
交换什么?
路由器交换的信息是自己的路由表。
每个路由表项目都有三个关键数据:<目的网络N,距离d,下一跳路由器地址X>。对于每个相邻路由器发送过来的RIP报文,执行如下步骤:
例子
RIP协议报文字段
RIP优点:实现简单、开销小、收敛过程较快。
RIP缺点:好消息传得快,坏消息传的慢
OSPF最主要的特征就是使用分布式的链路状态协议。
和谁交换?
使用洪泛法向自治系统内所有路由器发送信息,即路由器通过输出端口向所有相邻的路由器发送信息,而每一个相邻路由器又再次将此信息发往其所有的相邻路由器。(广播)
最终整个区域内所有路由器都得到了这个信息的一个副本。
----- 而RIP仅向自己相邻的几个路由器发送信息。
交换什么?
发送的信息就是与本路由器相邻的所有路由器的链路状态(本路由器和哪些路由器相邻,以及该链路的度量/代价 —— 费用、距离、时延、带宽等)。
----- 而RIP发送的信息是本路由器所知道的全部信息,即整个路由表。
多久交换?
只有当链路状态发生变化时,路由器才向所有路由器洪泛发送此信息。收敛过程快,不会出现“坏消息传得慢”的问题。
最终,所有路由器都能建立一个链路状态数据库,即全网拓扑图。
----- 而RIP中,路由器之间会定期交换路由表的信息。
为了确保链路状态数据库与全网状态保持一致,OSPF规定每隔一段时间(30分钟)就刷新一次数据库中的链路状态。由于一个路由器的链路状态只涉及与相邻路由器的连通状态,因而与整个互联网的规模并无直接关系。当互联网规模很大时,OSPF要比RIP好得多。
OSPF的区域
为使OSPF能够用于规模很大的网络,OSPF将一个自治系统再划分为若干更小的范围,称为区域。
每个区域都有一个32位的区域标识符。
划分区域的好处是,将利用洪泛法交换链路状态信息的范围局限于每个区域而非整个自治系统,减少了整个网络上的通信量。在一个区域内部的路由器只知道本区域的完整网络拓扑,而不知道其他区域的网络拓扑情况。
处在上层的域称为主干区域,负责连通其他下层的区域,并且还连接其他自治域。
OSPF分组
OSPF特点
边界网关协议(Border Gateway Protocol,BGP)是不同自治系统的路由器之间交换路由信息的协议,是一种外部网关协议。
路由表包含已知路由器的列表、路由器能够达到的地址及到达每个路由器的路径的跳数。
BGP只能力求寻找一条能够到达目的网络且比较好的路由,而并非寻找一条最佳路由。
BGP采用的是路径向量路由选择协议。
BGP是应用层协议,它是基于TCP的。
和谁交换?
与其他AS的邻站BGP发言人交换信息。
交换什么?
交换的网络可达性的信息,即要到达某个网络所要经过的一系列AS。
多久交换?
发生变化时更新有变化的部分。
BGP协议报文格式
一个BGP发言人与其他自治系统中的BGP发言人要交换路由信息,就要先建立TCP连接,即通过TCP传送,然后在此连接上交换BGP报文以建立BGP会话(session),利用BGP会话交换路由信息。
BGP工作原理
每个自治系统的管理员要选择至少一个路由器(可以有多个)作为该自治系统的“BGP发言人”。一个BGP发言人与其他自治系统中的BGP发言人要交换路由信息,就要先建立TCP连接(BGP报文是TCP报文的数据部分),然后在此连接上交换BGP报文以建立 BGP会话,再利用BGP会话交换路由信息。当所有 BGP发言人都相互交换网络可达性的信息后,各 BGP发言人就可找出到达各个自治系统的较好路由。
每个 BGP发言人除必须运行BGP外,还必须运行该AS所用的内部网关协议,如 OSPF 或RIP。BGP所交换的网络可达性信息就是要到达某个网络(用网络前缀表示)所要经过的一系列AS。
BGP特点
BGP-4共使用4种报文
单播:单播用于发送数据包到单个目的地,且每发送一份单播报文都使用一个单播IP地址作为目的地址。是一种 点对点传输方式。
广播:广播是指发送数据包到同一广播域或子网内的所有备份的一种数据传输方式,是一种点对多点传输方式。
组播(多播):当网络中的某些用户需要特定数据时,组播数据发送者仅发送一次数据,借助组播路由协议为组播数据包建立组播分发树,被传递的数据到达距离用户端尽可能近的节点后才开始复制和分发,是一种点对多点传输方式。
使用组播的缘由:
有的应用程序要把一个分组发送给多个目的地主机。不是让源主机给每个目的地主机都发送一个单独的分组,而是让源主机把单个分组发送给一个组播地址,该组播地址标识一组地址。网络把这个分组的副本投递给该组中的每台主机。
主机可以选择加入或离开一个组,因此一台主机可以同时属于多个组。
主机组播时仅发送一份数据,只有数据在传送路径出现分岔时才将分组复制后继续转发。因此,对于发送方而言,数据只需发送一次就可发送到所有接收者,大大减轻了网络的负载和发送者的负担。
组播需要路由器的支持才能实现,能够运行组播协议的路由器称为组播路由器。
IP组播地址让源设备能够将分组发送给一组设备。属于多播组的设备将被分配一个组播组IP地址。
IP组播使用D类地址格式。D类的前四位是1110,因此D类地址范围是 224.0.0.0 ~ 239.255.255.255。一个D类地址表示一个组播组。只能用作分组的目标地址。源地址总是为单播地址。
IP组播分为:
组播MAC地址以十六进制值 01-00-5E 打头,余下的6个十六进制位是根据IP组播组地址的最后23位转换得到的。
TCP/IP 协议使用的以太网多播地址的范围是:
从 01-00-5E-00-00-00 到 01-00-5E-7F-FF-FF。
由于组播IP地址与以太网硬件地址的映射关系不是唯一的,因此收到组播数据报的主机,还要在IP层利用软件进行过滤,把不是本主机要接收的数据包丢弃。
下图就是D类IP地址和48位以太网MAC地址的映射关系,映射只是存在于两类地址的后23位,因此D类地址不固定的中间五位就会有多种对应的组播组,也就是多个组播组可能会对应映射到同一个MAC地址!
因特网组管理协议(Internet Group Management Protocol,IGMP)。
IGMP协议让路由器知道本局域网上是否有主机(的进程)参加或退出了某个组播组。
IGMP和ICMP都使用IP数据报传递报文。
IGMP工作的两个阶段:
ROUND 1:
ROUND 2:
组播路由选择目的就是要找出以源主机为根节点的组播转发树。
其中每个分组在每条链路上只传送一次。不同的多播组对应于不同的多播转发树:同一个多播组,对不同的源点也会有不同的多播转发树。
常用的三种算法:
移动IP技术是移动结点(计算机/服务器等)以固定的网络IP地址,实现跨越不同网段的漫游功能,并保证了基于网络IP的网络权限在漫游过程中不发生任何改变。
移动结点:具有永久IP地址的移动设备。
归属代理(本地代理):一个移动结点拥有的就“居所”称为归属网络,在归属网络中代表移动节点执行移动管理功能的实体叫做归属代理。
外部代理(外地代理):在外部网络中帮助移动节点完成移动管理功能的实体称为外部代理。
永久地址(归属地址/主地址):移动站点在归属网络中的原始地址。
转交地址(辅地址):移动站点在外部网络使用的临时地址。
路由器是一种具有多个输入端口和多个输出端口的专用计算机,其任务是连接异构网络并完成路由转发。
路由选择:根据所选定的路由选择协议构造出路由表,同时经常或定期和相邻路由器交换路由信息而不断地更新和维护路由表。
分组转发:由三部分组成,交换结构、一组输入端口、一组输出端口。
输入端口在从物理层收到地比特流中提取出数据链路层帧,进而从帧中提取出网络层数据报。
输出端口则执行恰好相反地操作。
交换结构:路由器的关键部件,根据转发表(路由表得来)对分组进行转发。
当源主机要向目标主机发送数据报时,路由器先检查源主机与目标主机是否连接在同一个网络上。
路由表隔离了广播域。
路由表根据路由选择算法得出的,主要用途是路由选择。总是用软件来实现!
路由表有4个项目:目的网络IP地址、子网掩码、下一跳IP地址、接口。
转发表从路由表得出的。可以用软件来实现,甚至也可以用特殊的硬件来实现!
转发表有2个项目:一个分组将要发往的目的地址、分组的下一跳(即下一步接收者的目的地址,实际为MAC地址。
转发和路由选择的区别:
转发是路由器根据转发表把收到的IP数据报从合适的端口转发出去,它仅涉及一个路由器。
路由选择 则涉及很多路由器,路由表是许多路由器协同工作的结果。这些路由器按照复杂的路由算法,根据从各相邻路由器得到的关于网络拓扑的变化情况,动态地改变所选择的路由,并由此构造出整个路由表。
传输层是主机才有的层次。
1、传输层提供进程和进程之间的逻辑通信。(网络层提供主机之间的通信)
逻辑通信:传输层之间的通信好像是沿着水平方向传送数据,但事实上这两个传输层之间并没有一条水平方向的物理连接。
2、复用和分用。复用是指发送方不同的应用进程都可以使用同一个传输层协议传送数据;分用是指接收方的传输层在剥去报文的首部后能够把这些数据正确交付到目的应用进程。
复用:应用层所有的应用进程都可以通过传输层再传输到网络层。
分用:传输层从网络层收到数据后交付指明的应用进程。
3、传输层对收到的报文进行差错检测(首部和数据部分)。【网络层只检查IP数据报的首部,不检验数据部分是否出错】。
4、提供两种不同的传输协议,即面向连接的TCP和无连接的UDP。【网络层无法同时实现两种协议】。
面向连接的传输控制协议TCP
传送数据之间必须建立连接,数据传送结束后要释放连接。不提供广播或多播服务。由于TCP要提供可靠的面向连接的传输服务,因此不可避免增加了许多开销:确认、流量控制、计时器及连接管理等。
可靠,面向连接,时延大,适用于大文件。
无连接的用户数据报协议UDP
传送数据之前不需要建立连接,收到UDP报文后也不需要给出任何确认。
不可靠,无连接,时延小,适用于小文件。
端口:传输层的服务访问点(SAP),标识主机中的应用进程。
数据链路层的SAP是MAC地址,网络层的SAP是IP地址。
端口号只有本地意义,在因特网中不同计算机的相同端口是没有联系的。
端口号长度为16bit,能标识65536个不同的端口号。
常见的应用程序与对应的端口号
在网络中采用发送方和接收方的套接字组合来识别端点,套接字唯一标识了网络中的一个主机和它上面的一个进程。
套接字 Socket = (主机IP地址,端口号)
UDP只在IP数据报服务之上增加了很少功能,即复用分用和差错检测功能。
面向报文:应用层给UDP多长的报文,UDP就照样发送,即一次发一个完整报文。
分用时,如果找不到对应的目的端口号,就丢弃报文,并给发送方发送ICMP“端口不可达”的差错报告报文。
在计算校验和时,要在UDP数据报之前增加12B的伪首部,伪首部并不是UDP的真正首部。只是在计算校验和时,临时添加在UDP数据报的前面,得到一个临时的UDP数据报。
17:封装UDP报文的IP数据报首部协议字段是17。
UDP长度:UDP首部8B + 数据部分长度(不包括伪首部)。
在发送端:
1、添上伪首部。
2、全0填充校验和字段。
3、全0填充数据部分。
4、伪首部 + 首部 + 数据部分 采用二进制反码求和。
5、把和求反码填入校验和字段。
6、去掉伪首部,发送。
在接收端:
1、添上伪首部。
2、伪首部 + 首部 + 数据部分 采用二进制反码求和。
3、结果全为1则无差错,否则丢弃数据报/交给应用层附上出错的警告。
1、TCP是面向连接(虚连接)的传输层协议。
2、每一条TCP连接只能有两个端点,每一条TCP连接只能是点对点的。
3、TCP提供可靠交付的服务,无差错、不丢失、不重复、按序到达。(可靠有序,不丢不重)
4、TCP提供全双工通信。允许通信双方的应用进程在任何时候都能发送数据,为此链段设有发送缓存和接收缓存。
5、TCP面向字节流:TCP把应用程序交下来的数据看成仅仅是一连串的无结构的字节流。
序号:在一个TCP连接中传送的字节流中的每一个字节都按顺序编号,本字段表示本报文段所发送数据的第一个字节的序号。
确认号:期望收到对方下一个报文段的第一个数据字节的序号。若确认号为 N,则证明到序号 N - 1 为止的所有数据都已正确收到。
数据偏移(首部长度):TCP报文段的数据起始处距离TCP报文段的起始处有多远,以4B为单位。
窗口:指的是发送本报文段的一方的接收窗口,即现在允许对方发送的数据量。
检验和:检验首部 + 数据,检验时要加上12B伪首部,第四个字段为6。
紧急指针:URG = 1时才有意义,指出本报文段中紧急数据的字节数。
选项:最大报文段长度MSS、窗口扩大、时间戳、选择确认 ……
六个控制位:
TCP连接传输三个阶段:
连接建立 — 数据传送 — 连接释放
1、客户端发送连接请求报文段,无应用层数据。
SYN = 1,seq = x(随机)
2、服务器端为该TCP连接分配缓存和变量,并向客户端返回确认报文段,允许连接,无应用层数据。
SYN = 1,ACK = 1,seq = y(随机),ack = x + 1(客户端发送的seq是x,因此我期望收到的下一个序号就是x+1)
3、客户端为该TCP连接分配缓存和变量,并向服务器返回确认的确认,可以携带数据。
SYN = 0,ACK = 1,seq = x + 1(客户端第一次发送即第一步时定义的序号是seq=x,因此下一次发送按序就是seq=x+1),ack = y + 1
ACK为1时候,ack要出现!
SYN洪泛攻击发生在OSl第四层,这种方式利用TCP协议的特性,就是三次握手。攻击者发送TCP SYN,SYN是TCP三次握手中的第一个数据包,而当服务器返回ACK后,该攻击者就不对其进行再确认,那这个TCP连接就处于挂起状态,也就是所谓的半连接状态,服务器收不到再确认的话,还会重复发送ACK给攻击者。这样更加会浪费服务器的资源。攻击者就对服务器发送非常大量的这种TCP连接,由于每一个都没法完成三次握手,所以在服务器上,这些TCP连接会因为挂起状态而消耗CPU和内存,最后服务器可能死机,就无法为正常用户提供服务了。
参与一条TCP连接的两个进程中的任何一个都能终止该连接,连接结束后,主机中的缓存和变量将被释放。
1、客户端发送连接释放报文段,停止发送数据,主动关闭TCP连接。(无需确认位ACK此时=0)
FIN = 1,seq = u(u其实等于客户端发送的最后一个报文段序号+1)
2、服务器端回送一个确认报文段,客户到服务器这个方向的连接就释放了 —— 半关闭状态。(表示服务器端仍可以发送)
ACK = 1,seq = v(v其实等于服务器发送的最后一个报文段序号+1),ack = u + 1(上一步的报文seq=u,因此期待的下一个报文段序号就是u+1)
3、服务器发完数据,就发出连接释放报文段,主动关闭TCP连接。
FIN = 1,ACK = 1,seq = w(w其实等于服务器发送的最后一个报文段序号+1),ack = u + 1(上一步的报文seq=u,因此期待的下一个报文段序号就是u+1)
4、客户端回送一个确认报文段,再等到时间等待计时器设置的 2MSL(最长报文段寿命)后,连接彻底关闭。
ACK = 1,seq = u + 1(u+1就是客户端第一次发送的序号seq=u的下一个序号),ack = w + 1(服务器上一步发送的seq=w,期待服务器的下一个报文序号是w+1)
可靠:保证接收方进程从缓存区读出的字节流与发送方发出的字节流是完全一样的。
TCP 实现可靠传输的机制:1、校验 2、序号 3、 确认 4、重传。
冗余ACK(冗余确认)
用来解决TCP超时重传超时时间内干等的情况!
每当比期望序号大的失序报文段到达时,发送一个冗余ACK,指明下一个期待字节的序号。
发送方已发送1,2,3,4,5报文段
流量控制:让发送方慢点,要让接收方来得及接收。
TCP利用滑动窗口机制实现流量控制。
在通信过程中,接收方根据自己 接收缓存 的大小,动态地调整发送方的发送窗口大小,即接收窗口 rwnd(接收方设置确认报文段的 窗口字段 来将 rwnd 通知给发送方),发送方的 发送窗口取接收窗口 rwnd 和拥塞窗口 cwnd 的最小值。
发送窗口大小可以动态变化。
例子
防止报文丢失
TCP为每一个连接设有一个持续计时器,只要TCP连接的一方收到对方的零窗口通知,就启动持续计时器。
若持续计时器设置的时间到期,就发送一个零窗口探测报文段。接收方收到探测报文段时给出的现在的窗口值,
若窗口仍然是0,那么发送方就重新设置持续计时器。
拥塞控制:防止过多的数据注入到网络中。全局性。对资源的需求总和大于可用资源!
流量控制是点对点的。拥塞控制是全局性问题!
拥塞控制四种算法
前两种放在一起使用,后两种放在一起使用!
假定:
发送窗口 = Min{接收窗口 rwnd,拥塞窗口 cwnd}
接收窗口:接收方根据接受缓存设置的值,并告知给发送方,反映接收方容量。
拥塞窗口: 发送方根据自己估算的网络拥塞程度而设置的窗口值,反映网络当前容量。
慢开始和拥塞避免
ssthresh:慢开始门限
快重传和快恢复
应用层对应用程序的通信提供服务。
应用层协议定义:
应用层的功能:文件传输、访问和管理;电子邮件;虚拟终端;查询服务和远程作业登录
应用层的重要协议:FTP、SMTP、POP3、DNS
网络应用模型
客户/服务器模型(Client/Server)
服务器:提供计算服务的设备。
客户机:请求计算服务的主机。
应用:Web、文件传输FTP、远程登录、电子邮件。
P2P模型(Peer-to-peer)
不存在永远在线的服务器
每个主机既可以提供服务,也可以请求服务。
任意端系统/结点之间可以直接通讯。
结点间歇性接入网络。
结点可能改变IP地址。
可拓展性好,网络健壮性强。
Domain Name System
DNS系统采用客户/服务器模型,其协议运行在UDP之上,使用 53 号端口。
域名
级别最低的域名写在最左边,级别最高的顶级域名写在最右边。
从左到右:顶级域名->二级域名->三级域名…
顶级域名(Top Level Domain,TLD)
1、国家顶级域名。国家和某些地区的域名,如“.cn”表示中国,“.us”表示美国。
2、通用顶级域名。常见的有“.com”(公司)、“.net”(网络服务机构)、“.org”(非营利性组织)和“.gov”(国家或政府部门)等。
3、基础结构域名。这种域名只有一个,即 arpa,用于反向域名解析,因此又称反向域名。
根域名服务器
最高层次的域名服务器,所有的根域名服务器都知道所有的顶级域名服务器的IP地址。
不管是哪个本地域名服务器,若要对因特网上任何一个域名进行解析,只要自己无法解析,就首先要求助于根域名服务器。
因特网上有 13 个根域名服务器。
通常它并不直接把待查询的域名直接转换成IP地址,而是告诉本地域名服务器下一步应当找哪个顶级域名服务器。
顶级域名服务器
负责管理在该顶级域名服务器注册的所有二级域名。
权限域名服务器
每台主机都必须在权限域名服务器处等登记。
权限域名服务器总能将其管辖的主机名转换为该主机的IP地址。
本地域名服务器
当一个主机发出DNS查询请求时,这个查询请求报文就发给本地域名服务器。
域名解析过程(递归查询&迭代查询)
域名解析是指把域名映射成为 IP 地址或把 IP 地址映射成域名的过程。
前者称为正向解析,后者称为反向解析。
为了提高DNS的查询效率,在域名服务器中广泛使用了高速缓存。
文件传送协议(File Transfer Protocol):提供不同种类主机系统(硬、软件体系等都可以不同)之间的文件传输能力。
文件传送协议FTP(File Transfer Protocol)
简单文件传送协议TFTP (Trivial File Transfer Protocol)
FTP 是基于客户/服务器(C/S)的协议,使用TCP可靠的传输服务。
用户通过一个客户机程序连接至在远程计算机上运行的服务器程序。
依照FTP协议提供服务,进行文件传送的计算机就是 FTP服务器。
连接FTP服务器,遵循FTP协议与服务器传送文件的电脑就是FTP客户端。
FTP工作原理
FTP服务器进程由两大部分组成:一个主进程,负责接收新的请求;另外有若干从属进程,负责处理单个请求。
工作步骤如下:
1、打开熟知端口 21 (控制端口),使客户进程能够连接上。
2、等待客户进程发连接请求。
3、启动从属进程来处理客户进程发来的请求。主进程与从属进程并发执行,从属进程对客户进程的请求处理完毕后即终止。
4、回到等待状态,继续接收其他客户进程的请求。
数据连接有两种传输模式:主动模式 PORT 和 被动模式 PASV。
主动方式使用 TCP 20端口,被动方式由服务器和客户端自行协商决定(端口 > 1024)。
FTP传输模式
1、用户代理(User Agent,UA)
用户与电子邮件系统的接口。
用户代理向用户提供一个很友好的接口来发送和接收邮件。
用户代理应当具有撰写、显示和邮件处理的功能。
通常情况下,用户代理是一个运行在PC上的程序,常见的有 Outlook、Foxmail。
2、邮件服务器
发送和接收文件,同时向发信人报告邮件传送的情况。
采用客户/服务器方式工作,必须能够同时充当客户和服务器。
3、邮件发送协议和读取协议
邮件发送协议用于用户代理向邮件服务器发送邮件或在邮件服务器之间发送邮件,如SMTP。
邮件读取协议用于用户代理从邮件服务器读取邮件,如POP3。
**简单邮件传送协议(Simple Mail Transfer Protocol,SMTP)**是一种提供可靠且有效的电子邮件传输的协议。
规定了在两个相互通信的SMTP进程之间应如何交换信息。
负责发送邮件的SMTP进程就是SMTP客户,负责接收邮件的进程就是SMTP服务器。
SMTP规定了14条命令(几个字母)和21种应答信息(三位数字代码+简单文字说明)
SMTP使用TCP连接,端口号为25。使用C/S方式!
SMTP通信有以下三个阶段:1、连接建立 2、邮件传送 3、连接释放
SMTP的缺点:
由于SMTP只能传送一定长度的 ASCII 码,许多其他非英语国家的文字就无法传送,且无法传送可执行文件及其他二进制对象,因此提出了多用途网络邮件扩充 MIME。
改进SMTP协议!
MIME 继续使用SMTP的格式,但增加了邮件主体的结构,并定义了传送非 ASCII 码的编码规则。
使电子邮件系统可以支持声音、图像、视频多种国家语言。
主要包括以下三部分:
邮局协议(Post Office Protocol,POP)是一个非常简单但功能有限的邮件读取协议。
POP 使用客户/服务器的工作方式,在传输层使用TCP,端口号为110。
两种工作方式:1、下载并保留(在服务器)2、下载并删除。
对POP3和SMTP协议改进!
IMAP协议比POP协议复杂。当用户pc上的IMAP客户程序打开IMAP服务器的邮箱时,用户可以看到邮箱的首部,若用户需要打开某个邮件,该邮件才上传到用户的计算机上。
IMAP可以让用户在不同的地方使用不同的计算机随时上网阅读处理邮件,还允许只读取邮件中的某一个部分(先看正文,有WiFi的时候再下载附件)。
发送方和接收方到邮件的协议使用HTTP协议!
万维网(World Wide Web,WWW)是一个分布式的、联机式的信息存储空间,
在这个空间中:一样有用的事物称为一样 “资源”,并由一个全域“统一资源定位符”(URL)标识。
用户通过点击超链接(http://www.baidu.com)获取资源,这些资源通过“超文本传输协议(HTTP)传送给使用者。
万维网以“客户/服务器“方式工作,用户使用的浏览器就是万维网客户程序,万维网文档所驻留的主机运行服务器程序。
万维网使用超文本标记语言 HTML,使得万维网页面设计者可以很方便地从一个界面的链接转到另一个界面,并能够在自己的屏幕上显示出来。
HTTP协议定义了浏览器(万维网客户进程)怎样向万维网服务器请求万维网文档,以及服务器怎样把文档传送给浏览器。
HTTP协议的特点
对于非持久连接
每个网页元素对象的传输都需要单独建立一个TCP连接。
请求一个万维网文档所需的时间是该文档的传输时间加上两倍往返时间RTT(一个RTT用于TCP连接,另一个RTT用于HTTP请求)。
每个对象引用都导致 2xRTT的开销,此外每次建立新的TCP连接都要分配缓存和变量,使万维网服务器的负担很重。
对于持久连接
指万维网服务器在发送响应后仍然保持这条连接,使同一个客户和该服务器可以继续在这条连接上传送后续的HTTP请求和响应报文。
对于非流水线方式,客户在收到前一个响应后才能发出下一个请求,服务器发送完一个对象后,其TCP连接就处于空闲状态,浪费了服务器资源。
HTTP/1.1的默认方式是使用流水线的持久连接,这种情况下,客户每遇到一个对象引用就立即发出一个请求,因而客户可以逐个地连续发出对各个引用对象的请求。所有引用的对象共计经历1个RTT延迟,提高效率。
HTTP是面向文本的,因此报文种的每个字段都是一些ASCII码串,并且每个字段的长度都是不确定的。