该笔记也是我考研期间做的整理。一般网上的笔记是按照章节纪录的,我是按照知识点分类纪录的,大纲如下:
重要程度 | 分类 | 需记 |
---|---|---|
★ | HTTP报文段 | 请求行:方法 请求URL HTTP协议版本 状态行:版本 状态码 短语 |
★★ | UDP数据报 | 首部长8B,4个字段都是2B 长度字段(1) = 首部 + 数据 检验和(可选) => 伪首部 + 首部 + 数据 面向报文:既不合并、也不拆分 |
★★★ | TCP报文段 | **首部固定部分20B,最大60B **目的端口和源端口各占2B 序号:本报文段的第一个字节序号 确认号:期待收到下一个字节的序号 数据偏移=首部长度(单位4B) 检验和 => 伪首部 + 首部 + 数据 窗口:允许对方发送的数据量,并非表示自己的窗口。 |
★★★★ | IP分组 | 首部固定部分20B,最大60B 总长度(1)+片偏移(8)+首部长度(4) “一种八片首饰” 标志位:(?)+DF+MF 检验和 => 首部 源地址、目的地址各占4B |
★★★ | MAC帧 | 前同步码8B MAC地址长度6B 数据长度为46~1500B,首尾部共18B,帧长范围64~1518B 校验码 => 首部 + 数据 |
IP分组的单位:一种八片首饰(1总8片首4)
端口、IP、MAC(从上到下)的SAP长度:2B、4B、6B
应用程序 | FTP-控 | SMTP | DNS | HTTP | DHCP |
---|---|---|---|---|---|
协议 | TCP | TCP | UDP | TCP | UDP |
端口 | 21 | 25 | 53 | 80 | 68请求 69回应 |
端口
纯ALOHA协议——不听就说
有话直说,发生冲突则随机等待一段时间
时隙ALOHA协议——不听就说,整点发送
背景:纯ALOHA发送具有随机性,导致更多的冲突发生
例如将发送时间规定在01:00, 02:00, 03:00, …, 24:00,那么在下午15:34要说的话,就推迟到16:00发出去。(实际上不会隔那么久,这里假设T0=1h)
而如果发生碰撞,则继续采用纯ALOHA协议的方法。
1-坚持 CSMA——100%
发前先监听信道,若信道空闲,则立即发送
否则持续监听并等待(本次发送100%要发送)。
如果发生冲突,则随机等待一段时间后再监听。
非坚持 CSMA——0%
发前先监听信道,若信道空闲,则立即发送
否则就放弃监听(本次发送0%要发送,也就是可以不发送)。
如果发生冲突或者信道忙,则随机等待一段时间后再监听。
p-坚持 CSMA——p
发前先监听信道,若信道空闲,则按p概率发送,1-p概率推迟到下一个间隙。
否则就放弃监听,并在下一个间隙监听(本次发送只有p的概率会被发送)
当发生冲突时,采用二进制指数退避算法:
定义了帧间间隔(InterFrame Space, IFS)
只有在发出RTS之前会等待DIFS
其余发信号前均等待SIFS
处理隐蔽站问题
源站发送前,使用RTS(Request To Send)控制帧,包括源地址、目的地址、通信所持续的时间。
用来告知源站要在该时间内与其他人通信了,也用来告知目的站自己的发送请求。
接收站接受请求,发送CTS(Clear To Send)控制帧,包括通信所持续的时间。
用来告知其他人我要和源站通信了,也用来告知源站自己已经准备好了。
组成部分
MTU
最大传送单元的最小值并非是46,因为PPP采用点对点连接,无需采用CSMA/CD协议
具体组成部分
PPP帧:[F, A, C, 协议, 信息部分, FCS, F]
一些要求
面向字节的异步链路使用字节填充实现透明传输
面向比特的同步链路使用0比特填充实现透明传输
距离-向量路由算法的代表为RIP
链路状态路由算法的代表为OSPF
背景
无论是使用RIP还是OSPF,随着系统中路由的增加,路由表条目数会增多,扫描时间也会增加,因此引入层次路由的概念,将网络分为多个自治系统。
一个自治系统内部所使用的路由选择协议称为内部网关协议(IGP),也称域内路由选择。其中代表协议为RIP和OSPF。
自治系统之间所使用的路由选择协议称为外部网关协议(EGP),也称域间路由选择。其中代表的协议为BGP边界网关协议。
目的:A主机通过B的IP找到B主机的MAC
A发送:广播ARP请求分组
(源IP, 目的IP, 目的MAC, 源MAC) = (IPA, IPB, FF-FF-FF-FF-FF-FF, MACA)
B发送:单播ARP响应分组
(源IP, 目的IP, 目的MAC, 源MAC) = (IPB, IPA, MACA, MACB)
注意:如果跨网络,需要交给路由器这个中介完成,类似递归式地进行
目的:目标主机或目标路径上的路由器向源主机报告差错和异常情况。
ICMP有五种类型:
类型 | 含义 | 例子 |
---|---|---|
终点不可达 | 不能交付 | 1. 端口没打开 2. 端口没有应用程序接待 |
源点抑制 | 拥塞而丢弃 | 主机或路由器太忙了,没时间接待,直接丢掉了 |
时间超过 | TTL=0 | 中间途径的路由器太多了,导致TTL在半路就为0了 |
参数问题 | 检验和不通过 | 路由器检测到收到的数据有比特位错误了 |
改变路由 (重定向) |
可通过更好的路由 | 路由器检测到: 1. 从哪来又回哪去 2. 想发往远程网络的数据就在本网络 |
ICMP有四种情况不响应ICMP:
目的
过程解析
一些细节
客户端在第三次握手若不发送数据,则不消耗序号,并且在下次传输数据时,序号从x+1开始。
服务器资源是在第二次握手时分配,而客户端是在第三次握手才分配资源,这使得服务器易受到SYN泛洪攻击(DDoS攻击)。
一些问题
Q: 为什么还要第三次握手,两次握手不行吗?
A: 假设两次握手的情况:客户端发送了第一个连接请求报文(SYN=1, seq=x),由于网络拥塞,客户端超时重传发送了第二个连接请求报文(SYN=1, seq=x+1),服务器收到了第二个连接请求,并发回确认,与客户端开始交换数据,最后,断开连接。不巧的是,第一个连接请求报文后来又到达了服务端,服务端就开始分配资源并发回确认,但是实际上这个确认直接被客户端给拒绝了!也就是说服务器的资源被白白浪费了。引用原话:“The principle reason for the three-way handshake is to prevent old duplicate connection initiations from causing confusion.”
过程解析
客户端发完了
报文:发送连接释放报文(FIN=1, seq=x)
,此时客户端单方向地关闭了数据通路。
状态:进入FIN-WAIT-1(终止等待1)状态
服务器知道客户端发完了
报文:对连接释放报文发回确认(ACK=1, seq=y, ack=x+1)
状态:服务器进入CLOSE-WAIT(关闭等待)状态,客户端收到后进入FIN-WAIT-2(终止等待2)状态
服务器也发完了
报文:发送连接释放报文(FIN=1, seq=y+n, ack=x+1)
,n为从第二、三步之间发送的字节数。
状态:服务器进入LAST-ACK(最后确认)状态
客户端知道服务器发完了
报文:对连接释放报文发回确认(ACK=1, seq=x+1, ack=y+n+1)
状态:客户端先进入TIME-WAIT(等待计时器设置的2MSL最长报文寿命)状态,然后再进入到CLOSED(连接关闭)状态。而服务器直接进入到CLOSED(连接关闭)状态
服务特点
可靠传输
拥塞控制
(1) 定义
拥塞窗口cwnd:发送方的窗口
接收窗口rwnd:接收方的窗口
(2) 慢开始 & 拥塞避免
31
-32ssthresh=cwnd/2
;②cwnd=1
。(3) 快重传 & 快恢复
ssthresh=cwnd/2
; ②cwnd=cwnd/2
;可靠传输 与 拥塞控制的关系
可靠传输:滑动窗口的大小由接收方决定。
拥塞控制:滑动窗口的大小由网络拥塞情况决定。
滑动窗口仍然是服务于可靠传输,拥塞控制只是滑动窗口大小的动态调节机制。
当题目中二者同时出现时,选择其中最小的那个。(知识交叉:极限数据传输速率也是二者取小者)
拥塞控制的细节
拥塞窗口改变cwnd的时机并不是等待依次发送的cwnd个报文,而是每个RTT内会并行地发送cwnd个报文。
要认识到:①cwnd每RTT将可能改变一次;②一个RTT内的多个报文的发送不是串行,而是并行
目的:A主机向DHCP服务器申请并注册一个私有IP使用
为什么DHCP是应用层协议?
因为DHCP有DHCP服务器、DHCP客户,采用C/S模式,只要采用C/S模式的协议就是应用层协议
控制连接
数据连接-主动模式PORT
主动可理解为:服务器主动连接客户要求的端口
数据连接-被动模式PASV
被动可理解为:服务器被客户连接
一些细节
SMTP——TCP25
使用范围:发件人 => 发送方邮件服务器
、发送方邮件服务器 => 接收方邮件服务器
限制:只能传输一定长度的ASCII码邮件
MIME——SMTP的升级媒介(仅仅是翻译工作)
使用范围:发件人发之前由MIME“转码”后转交给SMTP、接收人收之前由MIME“恢复”
POP3(Post Office Protocal 3) 邮局协议——TCP110
使用范围:接收方从接收方服务器“拉取”邮件
特点:提供下载并保留、下载并删除工作方式
限制:无法分类,必须下载整个邮件才能读
IMAP——POP3的升级
使用范围:同POP3
特点:可以建立文件夹、可以在文件夹之间转移邮件、可以在文件夹内检索邮件、可以只读取一个报文的首部或者多部分MIME报文的一部分
电子邮件格式
From:[email protected]
To:[email protected]
Subject:Are you OK?
Hi, I'm LiHua, How are you?
I'm fine, thank you!
1~3:首部
4~:主体
SMTP连接过程解析
以下简写:SMTP客户为发送方SMTP服务器,SMTP服务器为接收方SMTP服务器。
(1) 连接建立
HELLO
命令,附上发送方的主机名(2) 邮件传送
MAIL
FROM:RCPT
(收件人recipient的缩写),RCPT TO:DATA
表示要发送数据了(先别发)(3) 连接释放
QUIT
命令整个过程简化为:
HELLO
,我的电脑名字MAIL
,我的邮箱RCPT
,我要发给的邮箱1RCPT
,我要发给的邮箱nDATA
,我准备发了你有什么要求QUIT
,传输结束设W为理想低通信道的带宽,V表示每个码元可表示的离散电平数目(实际上log2V意思就是一码元多少bit)
理想低通信道下的极限数据传输速率 = 2 W ( B a u d ) = 2 W l o g 2 V ( b / s ) 理想低通信道下的极限数据传输速率=2W(Baud)=2Wlog_2V(b/s) 理想低通信道下的极限数据传输速率=2W(Baud)=2Wlog2V(b/s)
设W为信道的带宽,S为信道所传输信号的平均功率,N为信道内部的高斯噪声功率。
信道的极限数据传输速率 = W l o g 2 ( 1 + S / N ) 信道的极限数据传输速率 = Wlog_2(1+S/N) 信道的极限数据传输速率=Wlog2(1+S/N)
扩展:信噪比=10log10(S/N) 分贝(dB),给定分贝单位的数据,要知道求S/N
最大限制
选择重传协议要求发送窗口WT与接收窗口WR最大的限制:WTmax=WRmax=2(n-1)
多维分析
发送窗口WT | 接收窗口WR | |
---|---|---|
停止-等待协议 | 1 | 1 |
后退N帧协议 | 1≤WT≤2n-1 (等于1时退化到停等协议) |
1 |
选择重传协议需满足:
TCP封装的
协议名称 | 所属层次 | 端口 | 功能 |
---|---|---|---|
BGP | 网络层 | 179 | 边界网关协议 |
FTP-控制 | 应用层 | 21 | 文件传输控制命令传输 |
SMTP | 应用层 | 25 | 简单邮件传输协议 |
HTTP | 应用层 | 80 | 超文本传输协议 |
POP3 | 应用层 | 110 | 邮局通讯协定第三版 |
TELNET | 应用层 | 23 | 远程登录 |
UDP封装的
协议名称 | 所属层次 | 端口 | 功能 |
---|---|---|---|
RIP | 网络层 | 520 | 路由信息协议 |
DHCP | 应用层 | 68 | 动态主机配置 |
DNS | 应用层 | 53 | 域名解析服务 |
TFTP | 应用层 | 69 | 普通文件传送协议 |
SNMP | 应用层 | 161 | 简单网络管理协议 |
IP封装的
协议名称 | 所属层次 | 功能 |
---|---|---|
OSPF | 网络层 | 开放最短路径优先协议 |
ARP | 网络层 | 地址解析协议 |
ICMP | 网络层 | 互联网控制消息协议 |
基本分类
类型 | 固定首位 | 范围 |
---|---|---|
A | 0 | 网络号1B,主机号3B |
B | 10 | 网络号2B,主机号2B |
C | 110 | 网络号3B,主机号1B |
D | 1110 | 多播地址 |
E | 1111 | 保留为今后使用 |
特别地址不作主机地址
私有地址不出现在Internet中
特殊的CIDE无分类编址IP
与IPv4的异同
IPv6 | IPv4 | |
---|---|---|
长度 | 16B(128位) | 4B(32位) |
首部长度 | 8nB | 4nB |
分片 | 不允许分片 | 允许分片 |
基本类型地址 | 单播、多播、 任播 | 单播 、多播 |
校验和 | 不校验 | 校验首部 |
基本格式:(目标网络的IP地址, 子网掩码, 下一跳, 接口)
关于下一跳:
默认网关的配置:
数据链路层知识P110
参数 | 10BASE2 | 10BASE5 | 10BASE-T | 10BASE-FL |
---|---|---|---|---|
传输媒体 | 基带同轴电缆(粗缆) | 基带同轴电缆(细缆) | 非屏蔽双绞线 | 光纤对 |
编码 | 曼彻斯特编码 | 曼彻斯特编码 | 曼彻斯特编码 | 曼彻斯特编码 |
拓扑结构 | 总线 | 总线 | 星型 | 点对点 |
最大段长 | 500m | 185m | 100m | 200m |
最多结点数目 | 100 | 30 | 2 | 2 |
这样记
数字就是粗缆细缆的意思,T就是Twisted-Pair即双绞线,FL就是Fiber Light即光纤(虽然不是这样翻译的)
双绞线在路由器见得多,而一个路由器连接多个电脑就像是星型一样。实际上双绞线的中心是集线器,在逻辑上依旧是总线,属于一个冲突域。
光纤要求比较多,弄一个中继器很难实现分发,所以干脆点到点。
另外两个就是总线型(总要有几个是总线型吧!)
软件定义网络,SDN(Software Defined Network)
传统路由器分为控制层面与数据层面,在近年流行的SDN中,将控制层面集中在了远程控制器
路由器的任务就是:
路由器无需的任务:
虚拟局域网,是数据链路层范畴,由交换机实现。
交换机隔离冲突域,不隔离广播域
但交换机实现的VLAN即隔离冲突域,又隔离广播域
以太网规定最短帧长为64B
若某物理链路采用CSMA/CD(载波监听多点接入/碰撞避免)算法控制访问介质,那么就需要考虑最短帧长
最短帧长 = 2 × ( 单向传输时延 + 单向传输时的其他耗时 ) × 宽带 最短帧长 = 2×(单向传输时延+单向传输时的其他耗时)×宽带 最短帧长=2×(单向传输时延+单向传输时的其他耗时)×宽带
该公式意思是,因为需要在发送过程中一直监听链路
在极限情况下,接收方刚准备接收就发生碰撞,因此会给发送方告知发生了碰撞,此时所需时间就是往返时延
若在往返时延之前就结束了发送,意味着不能监听到极限情况下的碰撞,也就丢失了这一个帧
通信子网:下三层(物理层、数据链路层、网络层)
资源子网:上三层(会话层、表示层、应用层)
传输层作为承上启下的作用。
调制:数字信号 转 模拟信号,基带 转 宽带
解调:模拟信号 转 数字信号,宽带 转 基带
作用
取自P142,用于网络层的拥塞控制
区别
【静态】开环控制:在设计网络时事先将有关发生拥塞的因数考虑周到,力求网络在工作时不产生拥塞。
【动态】闭环控制:事先不考虑,采用监测网络系统去监视,哪里拥塞就把拥塞消息传到合适的地方。
玄学记忆
闭环就是关起来,只有内部人员(网络系统监视)才可以维护。
而开环控制不需要维护(实现考虑周全),所以不需要闭起来了。
SAP:Server Access Point,服务访问点
数据链路层SAP:MAC地址
网络层SAP:IP地址
传输层SAP:端口号
一般性特征
能存储转发就能连接协议不同的网络。
主要作用:将信号整形并放大放出去
限制:不能连接两个速率不一致的局域网
区分:放大器放大的是模拟信号,中继器放大的是数字信号
遵守:5-4-3原则——用4个中继器连接的5个网络最多只有3段可以挂在主机
主要作用:实质上是多端口的中继器
限制:仅支持半双工,因此会均分带宽
结构:逻辑总线,物理星型
常用于远距离模拟信号的传输,但同时会使噪声放大,引起失真。
主要作用:多端口的网桥,隔离冲突域
相关联:本身不隔离广播域,但用交换机实现的虚拟局域网VLAN,则隔离广播域
特点:全双工、无冲突、自学习、N个端口的(10MB/s)交换机总容量为N×10MB/s
注意:交换机收到某未知单播、广播时,不会转发到发来的端口上
分类
直通式交换机 | 存储转发式交换机 | |
---|---|---|
检查范围 | 只检查帧的目的地址 | 整个帧 |
优点 | 延时低 | 可靠性高 |
缺点 | 可靠性低 | 需要缓存整个帧,延时高 |
不同速率端口兼容性 | 无法转换速率不同的端口 | 支持速率不同端口间的转换 |
如果转发本网络,无需经过路由器,直接交付
如果转发到其他网络,则需要根据转发表间接交付
两个表
路由表:由软件实现
转发表:从路由表得到,由软件或者硬件实现
实际上转发时靠的是转发表,而非路由表
ISO/OSI | TCP/IP | |
---|---|---|
传输层 | 面向连接 | 无连接 & 面向连接 |
网络层 | 无连接 & 面向连接 | 无连接 |
这样记
TCP/IP模型中,传输层UDP无连接、TCP面向连接,网络层IP无连接。
ISO/OSI是理论理想的,为了保证安全,传输层必须是面向连接的才安全,而传输层实现了面向连接,网络层有没有连接无所谓了。
物理层:采用曼彻斯特编码,每位数据需要两个电平表示,因此1Baud=0.5b/s
数据链路层:最小帧长64B
计算校验和之前,需要在原首部前加上12B的伪首部
伪首部结构:[源IP(4B), 目的IP(4B), 0(1B), 17/6(1B), UDP/TCP长度(2B)],其中UDP/TPC长度=原来UDP/TCP数据报的首部+数据长度。不包括伪首部的长度。
伪首部第四个是协议字段,UDP的伪首部为17,TCP的伪首部为6。
伪首部既不向下传递也不向上递交,仅在计算校验和时出现。
校验和范围:伪首部+首部+数据部分
对于 Aaaa.bb-bb.cc(…)cc.com
对于source.cdn.taibai.cloud域名的DNS解析过程:
注意权限域名服务器以下的均为权限域名服务器
且注意cdn.taibai.cloud的权限域名服务器就可以告诉source.cdn.taibai.cloud的IP,无需再递归去找source.cdn.taibai.cloud权限域名服务器了,而且source.cdn.taibai.cloud根本不是权限域名服务器,而是实实在在的主机。
如有错误欢迎指正,本笔记主要参考资料:
[1] 王道论坛 2023年计算机网络考研复习指导 北京:电子工业出版社,2021.12
[2] 计算机网络谢希仁(第8版)