计算机网络重点概念整理-第五章 传输层【期末复习|考研复习】

第五章 传输层 【期末复习|考研复习】

计算机网络系列文章传送门:
第一章 计算机网络概述
第二章 物理层
第三章 数据链路层
第四章 网络层
第五章 传输层
第六章 应用层
第七章 网络安全
计算机网络整理-简称&缩写


文章目录

  • 第五章 传输层 【期末复习|考研复习】
  • 前言
  • 五、传输层
    • 5.1 传输层提供的服务
      • 5.1.1 传输层功能
      • 5.1.2 传输层的寻址与端口
    • 5.2 UDP协议
    • 5.3 TCP协议
      • 5.3.1 TCP协议的特点
      • 5.3.2 TCP报文段
      • 5.3.3 TCP管理连接
      • 5.3.4 TCP的可靠传输
      • 5.3.5 TCP的流量控制
      • 5.3.6 TCP的拥塞控制
  • 下一章 第六章 应用层


前言

给大家整理了一下计算机网络中的重点概念,以供大家期末复习和考研复习的时候使用。
参考资料是王道的计算机操作系统和西电的计算机操作系统。


五、传输层

5.1 传输层提供的服务

5.1.1 传输层功能

传输层的功能如下:1、传输层提供应用进程之间的逻辑通信即端到端的通信,与网络层之间的区别为网络层提供的是主机之间的逻辑通信,即使网络层协议不可靠,传输层同样能为应用程序提供可靠的服务。2、复用分用。复用是指发送方不同的应用进程都可以使用同一个传输层协议传送数据;分用是指接收方的传输层在剥去报文的首部后能把这些数据正确的交付到目的应用进程,网络层也同样有复用分用的功能。3、传输层还要对收到的报文进行差错检验,检验其首部和数据部分;而网络层是检查IP数据报的首部,不检验数据部分是否出错。4、传输层提供两种不同的传输协议即面向连接的TCP和无连接的UDP,而网络层无法实现两种协议要么只提供面向连接的服务如虚电路,要么只提供无连接服务如数据报,而不可能在网络层同时存在这两种方式。

5.1.2 传输层的寻址与端口

端口是传输层服务访问点TSAP,它在传输层的作用类似于IP地址在网络层的作用或MAC地址在数据链路层的作用,只不过IP地址和MAC地址标识的是主机而端口标识的是主机中的应用进程。传输层使用的是软件端口。
端口号采用16位标志端口号,一共为65535个端口。端口号分为服务器端使用端口号和客户端使用端口号。服务器端使用的端口号分为熟知端口号0到1023和登记端口号1024到49151。常用的端口号如下:文件传输协议FTP(21)、远程登录协议TELNET(23)、电子邮件传输协议SMTP(25)、域名系统协议DNS(53)、简单文件传输协议TFTP(69)、超文本传输协议HTTP(80)、简单网络管理协议SNMP(161)、超文本传输安全协议HTTPS(443)、邮局协议POP3(110)。
在网络中通过IP地址来标识和区别不同主机,通过端口号来标识和区别一台主机的不同进程,端口号拼接到IP地址即形成套接字Socket,在网络中采用发送方和接收方的套接字来识别端点。套接字实际上是一个通信端点,它唯一的标识网络中的一台主机和其上的一个应用进程。
TCP提供面向连接的服务在传输数据之前必须建立连接传输,结束后要释放连接。TCP不提供广播或组播服务。 TCP 要进行确认、流量控制、计时器及连接管理等,因此TCP适合用于可靠性更高的场合如文件传输协议FTP、超文本传输协议HTTP、远程登录协议TELNET等。UDP是一个无连接的非可靠传输层协议,它在IP之上仅提供两个服务,多路复用和对数据的错误检查,UDP在使用前不需要建立连接,收到UDP报文后也无需任何确认。UDP比较简单因此执行速度较快实时性更好,使用UDP的应用包括小文件传输协议TFTP、DNS、SNMP和实时传输协议RTP等。
IP数据包和UDP数据报的区别:IP数据报在网络层要经过路由的存储转发而UDP数据报在传输层的端到端的逻辑通信中传输,封装成IP数据包在网络层传输时,UDP数据报的信息对路由是不可见的。TCP和网络程序电路的区别:TCP报文段在传输层的端到端的逻辑通信中传输,对路由不可见,虚电路经过交换节点必须保存虚电路的状态信息,在网络层若采用虚电路的方式则无法提供无连接服务而传输层采用TCP不影响网络层提供无连接服务。

5.2 UDP协议

UDP仅在IP数据报的服务之上增加了复用分用及差错检验以及端口功能。UDP数据报包含两个部分:UDP首部和用户数据报,UDP首部有8B,有四个字段,包括源端口号、目的端口号、长度和校验和。
1、无需建立连接,不会引入建立连接的时延。2、无连接状态,因此能支持更多的活动客户机。3、分组首部开销小,TCP有20B的首部开销而UDP只有8B。4、UDP没有拥塞控制,满足以稳定速度发送,容忍丢失但不允许较大时延的要求。5、UDP支持一对一、一对多、多对一和多对多的需求。6、UDP不保证可靠交付,给因此所有的维护可靠性的工作可由用户在应用层来完成。7、UDP是面向报文的,仅在添加首部后就向下交付给IP层。
在这里插入图片描述

UDP的伪首部仅在计算和校验时用到。长度为12B。既不上交也不传。
UDP常用于DNS、SNMP、多媒体应用、IP电话、实时会议、流媒体等。
UDP的伪首部的第四字段时17,而TCP是6。

5.3 TCP协议

5.3.1 TCP协议的特点

其任务是在IP层不可靠的、尽力而为的服务的基础上确立一种可靠的数据传输服务。特点如下:1、TCP只能是一对一的。2、TCP提供可靠的交付服务保证无差错、不丢失、不重复且有序。3、TCP提供全双工通信并且TCP连接两端设有发送缓存和接收缓存用来临时存放双向通信的数据。4、TCP是面向连接的。5、TCP是面向字节流的。6、TCP报文的长度是由接收方窗口值和当前网络的拥塞程度来确定,而UDP报文的长度是由发送应用程序决定。

5.3.2 TCP报文段

TCP传送数据单元称为报文段,TCP报文段即可以用来运载数据也可以用来建立连接、释放连接和应答。一个TCP报文分为首部和数据两部分,整个TCP报文段作为IP数据报的数据部分封装在IP数据包中,其首部的前20字节是固定的,TCP报文段的首部最短为20B。
在这里插入图片描述

确认号是期望收到对方下一个报文段的第一个数据字节的序号如果确认后为N则导游序号N减1为止的所有数据已正确收到。
紧急位URG、确认位ACK(确认位为1有效,为0无效)、推送位PSH、复位位RST(表示出现严重差错必须重新连接)、同步位SYN(表明这是个连接请求或连接接受报文)、终止位FIN(释放连接)。

5.3.3 TCP管理连接

TCP是面向连接的协议,每个TCP连接都有三个阶段:连接建立、数据传输和连接释放。TCP连接的端口为套接字或插口,每个TCP连接唯一的被通信的两个端点确定,即被两个个套接字确定。TCP连接采用客户/服务器方式,主动发起连接建立的应用进程称为客户,而被动等待连接建立的应用进程称为服务器。
ACK-确认位,SYN-同步位(只有建立连接时SYN为1其余为0),FIN-终止位,ack确认号,seq序号。
在这里插入图片描述
连接建立:1、SYN=1,seq=x(随机)。2、SYN=1,ACK=1,seq=y,ack=x+1。3、SYN=0,ACK=1,seq=x+1,ack=y+1。
在这里插入图片描述
释放连接:1、FIN=1,seq=u。2、ACK=1,seq=v,ack=u+1。3、FIN=1,ACK=1,seq=w,ack=u+1。。4、FIN=0,ACK=1,seq=u+1,ack=w+1。必须等待2MSL最大报文段寿命后客户机才进入CLOSED状态。

5.3.4 TCP的可靠传输

TCP使用校验、序号、确认和重传等机制来达到可靠传输的目的,校验机制与UDP校验一样。TCP默认使用累计确认。TCP对于两种事件会导致对报文段进行重传:超时和冗余ACK。对于超时:TCP采用一种自适应算法记录一个报文段发出的时间以及收到相应确认的时间,这两个时间之差称为报文段的往返时间,而TCP保留一个RTT的加权平均值,它会随着新测量的RTT的样本值而变化。对于冗余ACK:当接收端收到3个以上的冗余AC K时则可以认为该报文段已丢失,则快速重传该报文段。
RTT的赋值=(1-a)oldRTT+anewRTT

5.3.5 TCP的流量控制

为了匹配发送方的发送速率与 接收方的读取速率,TCP提供流量控制服务来消除发送方使接收方缓存区溢出的可能性。TCP提供一种基于滑动窗口协议的流量控制机制,在通信过程中接收方根据自己接收缓存的大小动态的调整发送方的发送窗口大小称为接收窗口rwnd,即调整TCP报文段首部的窗口字段,来限制发送方向网络注入的报文的速率,同时发送方会根据其对当前网络拥塞程度的估计而确定窗口值,称为拥塞窗口cwnd。
TCP为每个连接设置一个持续的计时器,只要TCP收到对方零窗口通知,就启动持缓计时器,时间到期就发送一个零窗口探测报文段,接收方给出当前的窗口值若仍是零,则返回重新计时。
传输层和数据链路层的流量控制的区别:传输层定义的端到端用户之间的流量控制,数据链路层定义2个中间 的相邻节点的流量控制,另外数据链路层的滑动窗口协议的窗口大小不能动态变化而传输层的则可以动态变化。

5.3.6 TCP的拥塞控制

拥塞控制是指防止过多的数据注入网络保证网络中的路由器或链路不致过载,拥塞控制和流量控制的区别:拥塞控制是让网络能够承受现有的网络负荷,是一个全局性的过程涉及所有主机路由器。相反流量控制往往是指点对点的通信量的控制,是一个端到端的问题,他所要做的是抑制发送端发送数据的速率以便接收端来得及接收。两者也有相似的地方即都是通过控制发送方的发送速率来达到控制效果。
发送窗口的上限值=min{rwnd,cwnd}。拼车网建议标准定义了进行拥塞控制的4种算法:慢开始、拥塞避免、快重传和快恢复。
慢开始算法在TCP刚刚建立好并开始发送TCP报文段时,先令拥塞窗口cwnd等于1即一个最大报文段长度MSS,每收到一个对新报文段的确认将cwnd加1即增大一个MSS,用这样的方法逐步增大发送方的cwnd可使分组注入网络的速率更加合理。cwnd的大小指数式增长,直到cwnd的增大到一个规定的慢开始门限ssthresh然后改用拥塞避免算法。
拥塞避免算法的思路是当cwnd到达慢开始门限时,让拥塞窗口cwnd缓慢增大,每经过一个往返时延RTT就把发送方的拥塞窗口cwnd加1,使拥塞窗口cwnd线性规律缓慢增长。无论在慢开始阶段还是在拥塞避免阶段只要发送方判断网络出现拥塞未按时收到确认就把慢开始门限设置为出现拥塞时发送方的cwnd的值的一半,但不能小于2,然后把拥塞窗口cwnd的重新设置为1,执行慢开始算法。这样的目的是迅速减少主机发送到网络中的分组数,使得发生拥塞的路由器有足够的时间把队列中积压的分组处理完。cwnd值不能跃过ssthresh值。
快充传:当发送方连续收到3个重复的ACK报文时直接重传对方尚未收到的报文,而不必等待那个报文段设置的重传计时器超时。快恢复的算法原理如下:当发送方连续收到3个冗余ACK时执行快恢复算法,把慢开始门限设置为此时发送方cwnd的一半,这是为了预防网络发生拥塞。
在这里插入图片描述
在TCP建立和网络出现超时时采用慢开始和拥塞避免算法当发送方接收到冗余ACK采用快重传和快恢复算法

下一章 第六章 应用层

第六章 应用层

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/108021.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

替换所有的问号

这篇也是凑数的 哈哈.... 稍后会整合到算法通关第三关白银挑战 . 描述 : 给你一个仅包含小写英文字母和 ? 字符的字符串 s,请你将所有的 ? 转换为若干小写字母,使最终的字符串不包含任何 连续重复 的字符。 注意 : 不能 修改非 ? 字符 . 题目 : …

读图数据库实战笔记02_图数据建模

1. 概念 1.1. 实体 1.1.1. 通常用名词来表示 1.1.2. 描述一个领域中的事物或者事物类型 1.1.2.1. 汽车 1.1.2.2. 用户 1.1.2.3. 地理位置 1.1.3. 在逻辑模型和技术实现过程中,实体通常会变成“顶点” 1.2. 关系 1.2.1. 用动词(或动词短语&#…

[量化投资-学习笔记003]Python+TDengine从零开始搭建量化分析平台-Grafana画K线图

在前面两个笔记: PythonTDengine从零开始搭建量化分析平台-数据存储 PythonTDengine从零开始搭建量化分析平台-MA均线的多种实现方式 中有提到使用 Grafana 画图,不过画的都是均线。除了均线,Grafana 非常人性的提供了 K线图模块 搭配 TDeng…

设置Ubuntu 20.04的静态IP地址(wifi模式下)

一、引言 自己家用的Ubuntu的,重启后ip地址经常会改变,这个时候就需要我们手动配置静态IP了。 二、优点 给Ubuntu设置一个静态IP地址有以下几个好处: 持久性:静态IP地址是固定不变的,与设备的MAC地址绑定。这意味着…

【C++】STL容器——探究不同 [ 迭代器 ] 种类&在STL中的使用方式(15)

前言 大家好吖,欢迎来到 YY 滴C系列 ,热烈欢迎! 本章主要内容面向接触过C的老铁 主要内容含: 欢迎订阅 YY滴C专栏!更多干货持续更新!以下是传送门! 目录 引言:一.查看STL使用文档时…

网站不被谷歌收录的常见原因及解决办法

现如今的互联网中,流量获取的渠道多种多样,但对于独立站而言,Google仍然是一个重要的流量来源。这是因为Google拥有庞大的用户基础,通过Google可以让潜在用户更容易发现我们的网站。然而,现实情况是,一些网…

OSPF,RIP和BGP的路由汇总

OSPF路由汇总 OSPF的路由汇总需要注意以下两点 1.OSPF的路由汇总仅支持手动汇总 注:距离矢量路由协议支持自动路由汇总,链路状态路由协议仅支持手动路由汇总(OSPF,ISIS) 2.OSPF的路由汇总只在区域边界进行汇总 OSPF的路由汇总…

Linux系统下DHCP服务安装部署和使用实例详解(蜜罐)

目录 一、概述 二、具体配置如下: 一、概述 DHCP :动态主机设置协议(英语:Dynamic Host Configuration Protocol,DHCP)是一个局域网的网络协议,使用UDP协议工作,主要有两个用途&…

虚幻中的网络概述一

前置:在学习完turbo强大佬的多人fps之后发觉自己在虚幻网络方面还有许多基础知识不太清楚,结合安宁Ken大佬与虚幻官方文档进行补足。 补充:官方文档中的描述挺好的,自己只算是搬运和将两者结合加强理解。 学习虚幻中的网络先从虚…

RabbitMQ如何保证消息不丢失呢?

RabbitMQ 是一个流行的消息队列系统,用于在分布式应用程序之间传递消息。要确保消息不会丢失,可以采取以下一些措施: 持久化消息: RabbitMQ 允许你将消息标记为持久化的。这意味着消息将被写入磁盘,即使 RabbitMQ 服务…

JavaScrip的DOM接口

JavaScript的DOM(Document Object Model)是一种接口,它允许程序和脚本动态地访问和更新文档的内容、结构和样式。DOM是一种将HTML或XML文档表示为对象树的标准方式。 在JavaScript中,DOM提供了一种方式来操作HTML或XML文档的元素…

【BUG】Nginx转发失败解决方案

最近在做项目的时候出现了一个问题,琢磨了好久,来浅浅记录一下。 这个项目后端使用的是gateway网关和nacos实现动态的路由,前端使用nginx来管理前端资源,大体流程:浏览器发起请求,经过nginx代理&#xff0c…

Redis -- 基础知识3 数据类型及指令

FLUSHALL:清空所有键值对操作(最好别搞,删库要被绳之以法的) 1.string类型 1.介绍 1.redis的字符串,直接按照二进制进行存储,所以可以存储任何数据,取出时不需要转码 2.redis的string类型,限制大小最大为512M,因为为单线程模型为了操作短平快 2.操作 1.set与get set key value …

软考系列(系统架构师)- 2010年系统架构师软考案例分析考点

试题一 软件系统架构选择 【问题1】(7分) 在实际的软件项目开发中,采用恰当的架构风格是项目成功的保证。请用200字以内的文字说明什么是软件架构风格,并对主程序-子程序和管道-过滤器这两种架构风格的特点进行描述。 软件架构风…

MySQL——九、SQL编程

MySQL 一、触发器1、触发器简介2、创建触发器3、一些常见示例 二、存储过程1、什么是存储过程或者函数2、优点3、存储过程创建与调用 三、存储函数1、存储函数创建和调用2、修改存储函数3、删除存储函数 四、游标1、声明游标2、打开游标3、使用游标4、关闭游标游标案例 一、触发…

linux-vsftp虚拟多用户

目录 1.安装vsftp 2.安装DB工具,能转化普通文件为vsftpd识别数据库加密文件 3.创建登录虚拟用户的名单 4.加密文件 6.需要修改vsftpd的配置文件 7.修改vsftp的配置文件,加载支持虚拟用户模式 8.针对不同用户开启不同权限 9.重启服务 10.测试 安…

Winsows QT5.15安装教程——组件务必要选上Sources

文章目录 1 下载地址2 开始安装2.1 选择一个磁盘空间大的位置安装QT,安装完可能会占用30G以上的空间2.2 选择组件2.3 接下来进入傻瓜式安装 3 QT 组件一览3.1 “Preview”分类下的开发组件3.1.1 编译器模块。3.1.2 “Qt ”分类下的开发组件 1 下载地址 https://www…

pytorch 笔记:KLDivLoss

1 介绍 对于具有相同形状的张量 ypred​ 和 ytrue(ypred​ 是输入,ytrue​ 是目标),定义逐点KL散度为: 为了在计算时避免下溢问题,此KLDivLoss期望输入在对数空间中。如果log_targetTrue,则目标…

【Linux】Linux+Nginx部署项目

🥳🥳Welcome Huihuis Code World ! !🥳🥳 接下来看看由辉辉所写的关于Linux的相关操作吧 目录 🥳🥳Welcome Huihuis Code World ! !🥳🥳 一.单体项目的部署 0.我们需要将要进行部…

Notepad++安装插件和配置快捷键

Notepad是一款轻量级、开源的文件编辑工具,可以编辑、浏览文本文件、二进制文件、.cpp、.java、*.cs等文件。Notepad每隔1个月,就有一个新版本,其官网是: https://github.com/notepad-plus-plus/notepad-plus-plus。这里介绍其插件…