1.1计算机网络的分类
按网络范围分:广域网(WAN)、城域网(MAN)、局域网(LAN);根据网络用户:公网和专网。
1.2计算机网络的层次结构
TCP/IP四层模型与OSI体系结构的比较:
1.3层次结构设计的基本原则
这些层是相互独立的;
每一层都需要有足够的弹性;
这些层是完全分离的。
1.4计算机网络性能指标
速率:bps =比特/秒
延迟:传输延迟、传播延迟、排队延迟和处理延迟。
往返时间RTT:数据报文在端到端通信中的往返时间。
第二,物理层
物理层的功能是连接不同的物理设备并传输比特流。这一层为上层协议传输数据提供了可靠的物理介质。
简单来说,物理层保证原始数据可以在各种物理介质上传输。
物理层:
中继器[中继器,也叫放大器]:
同一局域网的再生信号;两个端口的网段必须是相同的协议;
53流程:10BASE-5以太网中,最多4个中继器串联,5段只能连接3台主机;
集线器:
再现和放大同一局域网的信号(多端口中继器);半双工,无法隔离冲突域或广播域。
道的基本理念:
信道是单向传输信息的媒介。通信电路包含发送通道和接收通道。
单工通信信道:只能在一个方向进行通信而没有反方向反馈的信道;
半双工通信信道:双方可以发送和接收信息,但不能同时发送或接收信息;
全双工通信信道:双方可以同时收发。
第三,数据链路层
3.1数据链路层概述
数据链路层根据物理层提供的服务向网络层提供服务。
它的基本服务是将网络层的数据可靠地传输到相邻节点的目标计算机的网络层。
数据链路层在不可靠的物理介质上提供可靠的传输。
这一层的功能包括:物理地址寻址、数据成帧、流量控制、数据错误检测、重传等。
关于数据链路层的重要知识点:
数据链路层为网络层提供可靠的数据传输;
数据的基本单位是帧;
主要协议:以太网协议;
两个重要的设备名称:网桥和交换机。
封装和成帧:“帧”是数据链路层的基本数据单位:
透明传输:
“透明”意味着即使控制字符在帧数据中,它们也应被视为不存在。也就是说,转义字符ESC被添加在控制字符之前。
3.2数据链路层的错误监控
错误检测:奇偶校验码,循环冗余校验码
奇偶校验码–限制:当有两个错误时,无法检测到任何错误。
循环校验码:根据传输或存储的数据生成固定位数的校验码。
3.3最大传输单元MTU
MTU(最大传输单元(Maximum Transmission Unit,MTU),数据链路层的数据帧不是无限的,数据帧的长度受到MTU的限制。
路径MTU:由链路中的最小MTU决定。
3.4以太网协议的详细说明
MAC地址:每台设备都有一个唯一的MAC地址,总共48位,用十六进制表示。
以太网协议:它是一种广泛使用的局域网技术,是一种应用于数据链路层的协议。使用以太网可以完成相邻设备的数据帧传输:
局域网分类:
以太网以太网IEEE802.3:
以太网是第一个广泛部署的高速局域网。
以太网数据速率很快。
以太网硬件便宜,网络成本低。
以太网帧结构:
类型:标识上层协议(2字节)
目的地和源地址:MAC地址(每个6字节)
数据:封装的上层协议的数据包(46~1500字节)
CRC:循环冗余码(4字节)
以太网最短帧:最短以太网帧为64字节;除了数据部分,以太网帧有18个字节;最短的数据是46字节;
MAC地址(物理地址、局域网地址)
MAC地址长度为6字节48位;
MAC地址是唯一的,每个网卡对应一个MAC地址;
通常采用十六进制记数法,每个字节代表一个十六进制数,用amp; # 8211;或者:连接;
MAC广播地址:ff-ff-ff-ff-ff。
四。网路层
网络层的目的是实现两个终端系统之间透明的数据传输,具体功能包括寻址和路由、连接建立、维护和终止等。
数据交换技术是报文交换(基本上被包代替):采用存储转发方式,数据交换单位是报文。
网络层涉及的协议很多,其中最重要的协议,也是TCP/IP-IP协议的核心协议。IP协议非常简单,只提供不可靠和无连接的传输服务。
IP协议的主要功能是无连接的数据报传输、数据报路由和差错控制。
IP协议配合ARP、RARP、ICMP和IGMP实现其功能。
我们将在下一部分总结具体的协议,关于网络层的要点如下:
1.网络层负责在子网之间路由数据包。此外,网络层还可以实现拥塞控制、互联网互联等功能;
2.基本数据单元是IP数据报;
3.主要协议包括:
ICMP(互联网控制消息协议);
地址解析协议(ARP);
RARP协议(反向地址解析协议)。
4.重要设备:路由器。
4.1 IP协议的详细说明
互联网协议是互联网网络层的核心协议。
虚拟互联网的出现:实际的计算机网络是复杂的;物理设备通过使用IP协议屏蔽物理网络之间的差异;当网络中的主机使用IP协议进行连接时,就不需要关注网络的细节,这样就形成了一个虚拟网络。
IP协议使复杂的真实网络成为一个虚拟的互联网络;解决了虚拟网络中数据报传输路径的问题。
其中,版本是指IP协议的版本,占4位,如IPv4、IPv6;报头长度表示IP报头长度,占4位,最大值为15位;
总长度表示IP数据报的总长度,占16位,最大值为65535;表示TTL IP数据报文在网络中的寿命,占8位;
协议表示IP数据承载的具体数据是什么协议,比如TCP和UDP。
4.2 IP协议转发流程
4.3 IP地址的子网划分
a类(8个网络号+24个主机号)、b类(16个网络号+16个主机号)和c类(24个网络号+8个主机号)
它可用于识别网络中的主机或路由器。D类地址用作组播地址,E类地址保留。
4.4网络地址转换的NAT技术
用在私有网络中,多台主机通过一个公共IP访问Internet,它减缓了IP地址的消耗,但增加了网络通信的复杂性。
NAT的工作原理:
出内网的IP数据报用NAT服务器拥有的合法公网IP地址替换其IP地址,并将替换关系记录在NAT转换表中;
从公网返回的IP数据报根据其目的IP地址搜索NAT转换表,用搜索到的内部私有IP地址替换目的IP地址,然后将IP数据报转发到内部网络。
4.5 ARP协议和RARP协议
地址解析协议ARP(Address Resolution Protocol):提供网卡(网络适配器)IP地址到相应硬件地址的动态映射。
网络层32位地址可以转换为数据链路层MAC48位地址。
RARP(反向地址解析协议)协议是指反向地址解析协议,可以将数据链路层的MAC48位地址转换为网络层的32位地址。
4.6 icmp协议的详细解释
互联网控制消息协议,可以报告错误消息或异常情况。ICMP消息封装在IP数据报中。
ICMP协议的应用:
Ping应用程序:排除网络故障;
Traceroute应用:可以检测网络中IP数据报的路径。
4.7网络层路由概述
路由算法要求:正确完整、计算简单、适应网络变化、稳定公平。
自治系统AS:指一个管理组织下的网络设备组。AS内部网络自主管理,对外提供一个或多个出入口。
自治系统中的路由协议是内部网关协议,如RIP、OSPF等。自治系统外部的路由协议是外部网关协议,比如BGP。
静态路由:手动配置,难度和复杂度较高;
动态路由:
链路路由算法LS:向所有隔壁路由发送信息收敛快;全局路由算法,每台路由器计算路由时,需要构建整个网络拓扑图;利用Dijkstra算法寻找从源网络到目的网络的最短路径;Dijkstra算法
距离向量路由算法DV:发送信息到所有隔壁路由收敛慢,会有环路;它以贝尔曼-福特方程(简称B-F方程)为基础;
****内部网关路由协议的4.8 RIP协议
RIP(路由信息协议)[应用层],基于距离向量的路由算法,小型AS(自治系统),适用于小型网络;RIP消息,封装到UDP数据报中。
RIP协议功能:
RIP通过跳数来测量路径(每台路由器都维护自己与其它路由器之间的距离记录);RIP的开销是在源路由器和目的子网之间定义的;RIP仅限于直径不超过15跳的网络;与隔壁交换所有信息,30次(主动广播)。
4.9内部网关路由协议OSPF协议
开放最短路径优先(OSPF)[网络层],
基于链路状态的路由算法(Dijkstra算法),大规模AS,适用于大规模网络,直接封装在IP数据报传输中。
OSPF议定书的优势:
安全性;
以相同的成本支持多条路径;
支持差异化的成本衡量;
支持单播路由和组播路由;
分层路由。
与RIP OSPF的比较(路由算法决定其性质):
4.10外部网关路由协议的BGP协议
BGP(边界网关协议)边缘网关协议【应用层】:是运行在AS之间的协议,寻找好的路由:第一次交换所有信息,后面只交换变化的部分,BGP封装成TCP段。
动词 (verb的缩写)传输层
第一个端到端,即主机到主机级别。传输层负责将上层数据分段,并提供可靠或不可靠的端到端传输。
此外,传输层必须处理端到端的错误控制和流量控制。
传输层的任务是根据通信子网的特点,最大限度地利用网络资源,提供两端系统会话层之间建立、维护和取消传输连接的功能,负责可靠的端到端数据传输。
在这一层,信息传输的协议数据单元称为段或消息。
网络层只根据网络地址将源节点发送的数据包传输到目的节点,而传输层负责将数据可靠地传输到相应的端口。
关注网络层:
传输层负责对上层数据进行分段,提供端到端、可靠或不可靠的传输,以及端到端的差错控制和流量控制问题;
主要协议有TCP(传输控制协议)和UDP(用户数据报协议);
重要:网关。
5.1 UDP协议详细信息
UDP(用户数据报协议)是一个非常简单的协议。
UDP协议的特点:
UDP是一种无连接协议;
UDP不能保证可靠的传递数据;
UDP面向消息传输;
UDP没有拥塞控制;
UDP报头开销非常小。
UDP数据报结构:
报头:8B,四个字段/2B[源端口|目的端口| UDP长度|校验和]
字段:应用程序数据
5.2 TCP协议的详细说明
Tcp(传输控制协议)是计算机网络中非常复杂的协议。
TCP的功能:
对应用层消息进行分段和重组;
面向应用的重用和分解;
实现端到端的流量控制;
拥塞控制;
传输层寻址;
对接收到的消息执行错误检测(检测报头和数据部分);
实现进程间端到端的可靠数据传输控制。
TCP的特征:
TCP是面向连接的协议;
TCP是面向字节流的协议;
TCP的一个连接有两端,即点对点通信;
TCP提供可靠的传输服务;
TCP提供全双工通信(每个TCP连接只能一对一);
5.2.1 TCP段结构:
最大数据段长度:封装在数据段中的应用层数据的最大长度。
TCP报头:
序列号字段:每个应用层数据的每个字节的TCP序列号。
确认序列号字段:期望从对方接收到的数据的字节序列号,即该序列号对应的字节尚未接收到。由ack_seq标识;
TCP报头的最短长度为20B,最长长度为60字节。但是长度必须是4B的整数倍。
TCP标签的功能:
5.3可靠传输的基本原则
基本原则:
数据传输中传输信道不可靠可能出现的情况:误码、乱序、重传、丢失。
基于不可靠信道实现可靠数据传输的措施:
检错:数据包传输过程中的误码检测是通过编码来实现的。
确认:接收方将接收状态反馈给发送方。
重新发送:发送方重新发送接收方没有正确接收的数据。
序列号:确保数据按顺序提交。
定时器:解决数据丢失问题;
Stop协议:是最简单的可靠传输协议,但其信道利用率不高。
ARQ(自动重复请求ARQ)协议:滑动窗口+累积确认大大提高了信道的利用率。
5.3.1TCP协议的可靠传输
基于连续ARQ协议,在某些情况下,重传效率不高,一些成功接收的字节会被重复传输。
5 . 3 . 2 TCP协议的流量控制
流量控制:让发送方低速发送数据。TCP协议使用滑动窗口来控制流量。
5.4 TCP协议的拥塞控制
拥塞控制和流量控制的区别:流量控制考虑的是点对点的流量控制,而拥塞控制考虑的是全网,是全局的考虑。
拥塞控制方法:慢启动算法+拥塞避免算法。
慢启动和拥塞避免:
【慢启动】拥塞窗口从1开始指数增长;
当达到阈值时,进入【拥塞避免】,变成+1增长;
【超时】,阈值变成当前cwnd的一半(不能lt; 2);
从[慢启动]开始,拥塞窗口从1呈指数增长。
快速重传和快速恢复:
发送方连续收到3个冗余ACK,不等待定时器超时就执行【快速重传】;
执行【快速恢复】,阈值会变成当前cwnd的一半(不lt; 2),从这个新的ssthresh点进入【拥塞避免】。
5.5 TCP连接的三次握手(重要)
TCP三次握手使用说明:
面试官:为什么需要三次握手?
第一次握手:当客户发送请求时,服务器知道客户可以发送;
第二次握手:服务器发送确认,此时客户知道服务器可以收发;
三次握手:当客户发送确认时,服务器知道客户可以收到。
建立连接(三次握手):
第一次:
向客户端服务器发送连接请求段,建立连接请求控制段(SYN=1),表示发送报文段的第一个数据字节的序号为X,代表整个报文段的序号(SEQ = X);客户端进入SYN_SEND(同步发送状态);
第二次:
服务器发回确认段,同意建立新连接的确认段(SYN=1),确认序列号字段有效(ACK=1)。服务器告诉客户端该段的序列号为y(seq=y),表示服务器已经接收到客户端序列号为X的段,准备接受客户端序列号为x+1的段(ACK _ SEQ = X+1);
服务器监听进入SYN_RCVD(同步接收状态);
第三次:
确认客户端服务器的相同连接。确认序列号字段有效(ACK=1),客户端当前消息段的序列号为x+1(seq=x+1),客户端期望接受服务器序列号为y+1的消息段(ACK _ seq = y+1);
当客户端发送ack时,客户端进入建立状态;当服务收到客户发送的ack时,也进入建立状态;三次握手的第一个便携式数据;
5.6 TCP连接的四个波形(重要)
释放(四波)
第一次:
向客户端服务器发送连接释放消息段。数据发送后,发送方请求释放连接(FIN=1),第一个发送的数据字节序号为X(seq = X);客户端状态从ESTABLISHED进入FIN _ WAIT _ 1(WAIT 1状态终止);
第二次:
向服务器客户端发送确认段,确认字号段有效(ACK=1),服务器发送的数据序号为y(seq=y),服务器期望的客户数据序号为x+1(ACK _ seq = x+1);服务器的状态从ESTABLISHED变为CLOSE _ WAIT在接收到ACK段时,客户端从FIN_WAIT_1进入FIN _ WAIT _ 2;
第三次:
向服务器客户端发送连接释放消息段,请求释放连接(FIN=1),确认字体大小段有效(ACK=1),表示服务器期望接收到序列号为x+1的客户端数据(ACK _ seq = x+1);表示自身发送的第一个字节序列号为Y+1(SEQ = Y+1);服务器状态从CLOSE_WAIT变为LAST_ACK(最后确认状态);
第四次:
向客户端服务器发送一个确认段,确认字号段有效(ACK=1),表示客户端发送的数据序号为x+1(seq=x+1),表示客户端期望从服务器接收的数据序号为Y+zhaodufu1(ACK _ SEQ = Y+zhaodufu1);客户端从FIN_WAIT_2进入TIME_WAIT,等待2MSL,进入关闭状态;服务器收到最后一个ACK后,进入CLOSEDby LAST _ ACK
为什么需要等2MSL?
最后一条消息未被确认;
确保发送方的ACK能够到达接收方;
如果在2MSL时间内没有收到,接收方将重新发送;
确保当前连接的所有消息都已过期。
不及物动词应用层
为操作系统或网络应用程序提供访问网络服务的接口。
应用层的关注点:
数据传输的基本单位是消息;
主要协议有FTP(文件传输协议)、Telnet(远程登录协议)、DNS(域名解析协议)、SMTP(邮件传输协议)、POP3(邮局协议)、HTTP(超文本传输协议)。
6.1 DNS的详细解释
DNS(域名系统)[C/S,UDP,port 53]:解决IP地址复杂难记的问题,存储并完成辖区内主机的域名到IP地址的映射。
域名解析的顺序:[1]浏览器缓存,[2]查找本地机器的hosts文件,[3]路由缓存,[4]查找DNS服务器(本地域名,顶级域名,根域名)-gt;:迭代和递归查询。
1.IP—amp; gt;DNS服务--gt;:记忆友好域名2。域名由点、字母、数字组成,分为一级域名(com、cn、net、gov、org)、二级域名(百度、淘宝、qq、阿里巴巴)、三级域名(www)(120852)。
6.2 DHCP协议的详细解释
DHCP(动态配置协议):是一种局域网协议,也是使用UDP协议的应用层协议。角色:自动分配IP地址给临时访问局域网的用户。
6.3 HTTP协议的详细说明
文件传输协议(FTP):控制连接(端口21):7位ASCII码格式的传输控制信息(连接,传输请求)。会议期间一直开放。
HTTP(超文本传输协议)[TCP,端口80]:是一种可靠的数据传输协议。在浏览器向服务器发送和接收消息之前,它会建立一个TCP连接。HTTP使用TCP连接(HTTP本身没有连接)。
HTTP请求消息模式:
GET:请求指定的页面信息并返回实体体;
POST:将数据提交给指定的资源进行请求处理;
DELETE:请求服务器删除指定的页面;
HEAD:请求读取URL标识的信息头,只返回消息头;
操作:请求一些选项的信息;
PUT:在指定的URL下存储文档。
HTTP工作的结构
6 . 3 . 2 HTTPS协议的详细说明
HTTPS(安全)是一种安全的HTTP协议,端口号为443。
基于HTTP协议,使用SSL或TLS对数据进行加密,验证对方身份,保护数据完整性。
微信扫码关注主机频道微信微信官方账号,我们将为您提供更多最新、最全、最专业的行业资讯和主持推广活动。
本文转载自CSDN博主“虫子的奋斗”的原创文章。原文链接:https://blog.csdn.net/Royalic/article/details/119985591
以上内容来自互联网,不代表本站全部观点!欢迎关注我们:zhujipindao.com
评论前必须登录!
注册