计算机网络_04_传输层

文章目录

  • 1.什么是传输层
  • 2.传输层提供了什么服务
  • 3.传输层协议TCP

1.什么是传输层

传输层是OSI七层体系架构中的第四层, TCP/IP四层体系架构中的第二层, 从通信和信息处理两方面来看,“传输层”既是面向通信部分的最高层,与下面的三层一起共同构建进行网络通信所需的线路和数据传输通道,同时又是面向用户的最低层,因为无论何种网络应用,最终都需要把各种数据报传送到对方。应用层的用户数据通过传输层协议在不同网络中的主机间进行传输,因为仅靠网络层把数据传送到目的主机上还是不够的,还必须把它交给目的主机的应用进程。
在这里插入图片描述
当网络层把源主机上发出的数据包传送给目的主机后,还需要将数据交到对应的应用程序进程. 位于两台网络主机间的真正数据通信主体不是这两台主机,而是两台主机中的各种网络应用进程。因为在同一时刻,两主机间可以进行多个应用通信. 而这里的应用进程识别就要依靠“传输层”了,它通过“端口”将不同应用进程进行对应的。
在这里插入图片描述

2.传输层提供了什么服务

传输层的主要作用就是为它的上层提供端到端的数据传输服务, 即保证应用层的数据能够从源主机安全的到达目的主机上对应的应用进程.

1.什么是端到端的服务?

端到端通信是传输层为主机之间上的应用进程提供的通信服务. 传输层的数据段通过网络层将数据段交付到对端主机的目的进程,不管目的主机有多远,中间有多少机器,只要在两头间的应用进程间建立连接,就说已经是端到端连接了(两个进程间的连接),即端到端是逻辑链路,这条路可能经过了很复杂的物理路线,但两端程序不管,就好像它们是直接相连的一样,只认为是两端的直连.
在这里插入图片描述
你比如你要将数据从A传送到E,中间可能经过A→B→C→D→E,对于传输层来说他并不知道b,c,d的存在,他只认为我的报文数据是从a直接到e的,这就叫做端到端。

2.如何实现端到端的服务?

传输层实现端到端的服务有两种方式,一种是面向连接的,一种是面向无连接的.

面向连接:在提供传输服务前需要先建立专门的传输连接(类似一条专门用于两个进程之间进行通信的虚拟信道),而且这条连接是可管理的,在需要或通信结束时进行拆除。面向连接的传输服务是可靠的传输服务,而且可提供拥塞控制和差错控制功能,如TCP提供的传输服务。

无连接:在提供服务前不需要建立专门的传输连接,直接向目的节点发送数据,不管是否有可传输的通道,只提供不可靠(仅做尽力传输)的传输服务,如UDP提供的传输服务。

上述服务与网络层提供的面向连接和无连接服务很像,但网络层是通信子网的一个组成部分,网络服务质量并不可靠,如频繁地丢失分组,网络层系统可能崩溃或不断地进行网络复位。对于这些情况,用户将束手无策,因为用户不能对通信子网加以控制。而传输层能对通信子网进行管理和控制(什么进行管理和控制,网络层信息该丢还是丢,只不过丢了之后能够知道并重新对数据进行发送或其它操作管理)。

3.传输层服务

传输层要完成端到端的透明数据传输,至少要分为两个步骤:一是应用进程之间虚拟传输连接的建立(此处仍仅针对面向连接的传输层协议),二是源端用户数据沿着传输连接传送到目的端。

在整个数据传输过程中,传输层服务需要完成以下8个方面的基本功能:传输层寻址、传输连接建立、数据传输、传输连接释放、流量控制、拥塞控制、多路复用和解复用、崩溃恢复.

4.连接与释放连接服务

|4.1传输层寻址

虽然网络层把数据分组从源主机传送到了目的主机,但是这并不代表数据的传输过程就全部完成了,因为数据分组还没有真正地交付给相应的应用进程,此时应用进程才是数据通信主体。而我们又知道,同一时间的通信双方可能存在许多并发应用进程,那么源端来的数据分组该交给哪个应用进程呢?这就涉及传输层的寻址问题了。

传输层(二)传输层寻址方案

|4.2连接建立

传输层有两个重要术语TSAP与TPDU,它们贯穿整个传输层数据连接以及传输服务的始末.

TSAP(Transport Layer Service Access Point):传输层服务访问点是上层(应用层)调用下层(传输层)的一个逻辑接口,其实就是我们所说的端口,端口用来标识应用层的进程.

TPDU(Transport Layer Data Unit):传输层与对等层之间传输的报文,也就是"数据段",其实每一层都有每一层的SAP和PDU.

传输层TCP数据段格式:
在这里插入图片描述

源端口号:16位的源端口中包含初始化通信的端口。源端口和源IP地址的作用是标识报文的返回地址。
目的端口号:16位的目的端口域定义传输的目的。这个端口指明报文接收计算机上的应用程序地址接口。
序列号:对数据包进行标记,以便在到达目的地后重新重装,假设当前的序列号为 s,发送数据长度为 l,则下次发送数据时的序列号为 s + l,每发送一次数据,就累加一次该数据字节数的大小。在建立连接时由计算机生成一个随机数作为序列号的初始值,用来解决网络包乱序问题。客户端的序列号为上一个服务器端的确认号.
确认序号:收到对方报文后都要发送一个确认报文(包含确认号)表示确认收到该报文,并表明期望收到的下一个报文段的序号值。 TCP 的可靠性,是建立在「每一个数据报文都需要被确认收到」的基础之上的,用来解决不丢包的问题。客户端的确认号,是上一个服务器端的序列号+负载数据.
数据偏移:TCP 报文段的头部长度 ,它指出了 TCP报文段的数据起始处距离TCP报文的起始处有多远。
由于 4 位二进制数能表示的最大十进制数字是 15,这也侧面限制了 TCP 首部的最大长度
保留: 保留为今后使用,但目前应置为 0
标志位: 6位标志位,每一位的值只有 0 和 1

  • ACK:当 ACK = 1 的时候,确认号(Acknowledgemt Number)有效,称携带 ACK 标志的 TCP 报文段为确认报文段,为0表示数据段不包含确认信息,确认号被忽略。TCP 规定,在连接建立后所有传送的报文段都必须把 ACK 设置为 1
  • SYN:当 SYN = 1 的时候,表明这是一个请求连接报文段。 一般称携带 SYN 标志的 TCP 报文段为同步报文段。 在 TCP 三次握手中的第一个报文就是同步报文段,在连接建立时用来同步序号。对方若同意建立连接,则应在响应的报文段中使 SYN = 1 和 ACK = 1。
  • FIN:当 FIN = 1 时,表示此报文段的发送方的数据已经发送完毕,并要求释放 TCP 连接。一般称携带 FIN 的报文段为结束报文段。在 TCP 四次挥手释放连接的时候,就会用到该标志。
  • RST:当 RST = 1时,表示 TCP 连接中出现严重错误,需要释放并重新建立连接。 一般称携带 RST 标志的 TCP 报文段为复位报文段。
  • PSH:当PSH=1时,表明该数据段高优先级,接收方TCP应尽快将数据推给接收程序,不要等到整个TCP序列缓存都填满了后再交付。
  • URG:当URG=1时,表明此数据段应尽快传送,而不要按本来的队列次序来传送。与紧急指针字段共同使用,紧急指针指出在本数据段中紧急数据所在的最后一个字节的位置,使接管方知道紧急数据有多长。

窗口大小:该字段明确指出了现在允许对方发送的数据量,它告诉对方本端的 TCP 接收缓冲区还能容纳多少字节的数据,这样对方就可以控制发送数据的速度。 窗口大小的值是指,从本报文段首部中的确认号算起,接收方目前允许对方发送的数据量。假如确认号是 701 ,窗口字段是 1000。这就表明,从 701 号算起,发送此报文段的一方还有接收 1000 (字节序号是 701 ~ 1700) 个字节的数据的接收缓存空间。
校验和:由发送端填充,接收端对 TCP 报文段执行 CRC 算法,以检验 TCP 报文段(头部+有效载荷)在传输过程中是否损坏,如果损坏这丢弃。
紧急指针:仅在 URG = 1 时才有意义,指出本数据段中的紧急数据字节数,同时指出了紧急数据的末尾在数据段中的位置,发送方 TCP 把紧急数据插入到本数据段有效载荷的最前面,而在紧急数据后面的数据仍是普通数据。
选项和填充:可扩展部分。

传输层建立/拒绝连接需要用到三种类型的TPDU一一CR,CC,RJ
CR:连接请求数据段
CC:连接确认数据段
RJ:拒绝数据段
传输层建立/拒绝连接的大致流程:
在这里插入图片描述
TCP建立连接/断开连接的流程:
在这里插入图片描述
TCP规定,建立连接时发送的同步数据段(即SYN = 1的报文段)不能携带数据,但要消耗掉一个序号.

  • Ⅰ:建立连接时,主机A发送同步报文,并将同步位SYN置为1,确认位ACK置为0(代表当前报文的确认序号无效),随机产生一个序列号seq=k,然后将该数据包发送给主机B,主机A进入SYN_SENT状态,等待主机B确认。
  • Ⅱ:主机B收到报文后由同步位SYN=1知道主机A请求建立连接,主机B将同步位SYN和确认位ACK都置为1,确认序号ack=J+1,随机产生一个序号seq=y,并将该报文发送给主机A以确认收到该连接请求,主机B进入SYN_RCVD状态。
  • Ⅲ:主机A收到确认报文后,检查ACK是否为1,再检查确认序号ack是否为k+1,如果正确则将确认位ACK置为1,ack=y+1(表示我收到你序号位y的报文了),并将该报文发送给主机B,主机B检查ACK是否为1,再检查ack是否为y+1,如果正确则成功建立连接,主机A和主机B进入ESTABLISHED状态,完成三次握手,随后主机A与主机B之间可以开始传输数据了。

断开连接:

  • Ⅰ:断开连接时,主机A发送一个终止报文,并将终止位FIN置为1,确认位ACK置为0,随机产生一个序列号seq=u,然后将该报文发送给主机B,用来关闭主机A到主机B的数据传送,主机A进入FIN_WAIT_1状态。
  • Ⅱ:主机B收到终止报文后,发送一个确认报文给主机A,并将确认位ACK置为1,确认序号ack=u+1,随机生成一个序号seq=v,主机B进入CLOSE_WAIT状态。
  • Ⅲ:主机B发送一个终止报文,并将终止位FIN置为1,确认位ACK置为1,随机序号seq=w,确认号=u+1,用来关闭主机B到主机A的数据传送,主机B进入LAST_ACK状态。
  • Ⅳ:主机A收到终止报文FIN后,主机A进入TIME_WAIT状态,接着发送一个确认报文ACK给主机B,确认序号为ack=w+1,序号seq=u+1,主机B进入CLOSED状态,完成四次挥手。

为什么建立连接是三次握手,而关闭连接却是四次挥手呢?

这是因为主机B在LISTEN状态下,收到建立连接请求的SYN报文后,把ACK和SYN放在一个报文里发送给主机A。而关闭连接时,当收到对方的FIN报文时,仅仅表示对方不再发送数据了但是还能接收数据,己方也未必全部数据都发送给对方了,所以己方可以立即close,也可以发送一些数据给对方后,再发送FIN报文给对方来表示同意现在关闭连接,因此,己方ACK和FIN一般都会分开发送。

5.数据传输服务

传输层在数据传输时提供了流量控制、拥塞控制、多路复用和解复用、崩溃恢复等服务.
传输层TCP的流量控制和拥塞控制(图文详解)
如何理解传输层的多路复用与多路分解

3.传输层协议TCP


补充:
通信子网(communication subnet,或简称子网): 是指网络中实现网络传输功能的设备及其软硬件的集合,传输设备、网络传输协议、传输控制软件等属于通信子网,是网络的内层,负责信息的传输. 简而言之就是由各种网络传输设备(中继器、集线器、网桥、路由器、网关等硬件设备)和传输线路组成,主要负责数据的传输. 通信子网对应OSI体系架构中的下三层(物理/数据链路/网络层).

资源子网:资源子网由计算机系统、终端、终端控制器、连网外设、各种软件资源与信息资源组成, 主要负责数据的处理和数据存储,资源子网对应OSI体系结构的上三层(应用/表示/会话层).
点到点传输:两个设备直接相连(中间不经过任何其它设备)的通信叫点到点通信。它只提供一台机器到另一台机器之间的通信,不会涉及到程序或进程的概念。
点到点通信是针对数据链路层或网络层来说的,因为数据链路层只负责直接相连的两个节点之间的通信,一个节点的数据链路层接受ip层数据并封装之后,就把数据帧从链路上发送到与其相邻的下一个节点。 点对点是基于MAC地址和或者IP地址,是指一个设备发数据给与该这边直接连接的其他设备,这台设备又在合适的时候将数据传递给与它相连的下一个设备,通过一台一台直接相连的设备把数据传递到接收端。由物理层、数据链路层和网络层组成的通信子网为网络环境中的主机提供点到点的服务.
序列号:TCP协议工作在OSI的传输层,是一种可靠的面向连接的数据流协议,TCP之所以可靠,是因为它保证了传送数据包的顺序。顺序是用一个序列号来保证的。响应包内也包括一个序列号,表示接收方准备好这个序列号的包。在TCP传送一个数据包时,它会把这个数据包放入重发队列中,同时启动计时器,如果收到了关于这个包的确认信息,便将此数据包从队列中删除,如果在计时器超时的时候仍然没有收到确认信息,则需要重新发送该数据包。另外,TCP通过数据分段中的序列号来保证所有传输的数据可以按照正常的顺序进行重组,从而保障数据传输的完整。
TCP序列号是两个方向的,每个方向有自己的序列号,这个序列号是随机产生的.
客户端的序列号为上一个服务器端的确认号,客户端的确认号,是上一个服务器端的序列号+负载数据.

参考:
端到端通信
TCP协议详解
TCP/IP协议详解
《深入理解计算机网络》之传输层总结

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

飞利浦双串口51单片机485网关

主要功能将PC端的数据接收下来,分发到不同的设备,也是轮询设备数据读取回来,打包回传到PC端,数据包包头包尾识别,数据校验,接收超时处理,将协议结构化处理,协议的改动不需要改动程序…

【数据结构】Map和Set

Map和Set 1. 搜索树 1.1 概念 二叉搜索树是左子树比根节点小,右子树比根节点大的二叉树。(如果左右子树不为空的话是这样,但是左右子树也可以为空) 1.2 操作——查找 查找的思想与二分查找类似。 如果根节点的值和所要查找的…

前端知识与基础应用

前端知识 什么是前端:所有和用户打交道的操作页面,我们都称之为前端 例如:pc页面,浏览器的主页面,手机页面等等,可以用肉眼看到的就是前端 什么是后端: 就是一堆代码,用户不能够直接…

Kitex踩坑 [Error] KITEX: processing request error,i/o timeout

报错问题 2023/010/28 17:20:10.250768 default_server_handler.go:234: [Error] KITEX: processing request error, remoteService, remoteAddr127.0.0.1:65425, errordefault codec read failed: read tcp 127.0.0.1:8888->127.0.0.1:65425: i/o timeout 分析原因 Hert…

内置视图联动查看器,实现数据关联分析

前言 在数据驱动业务发展的今天,数据的关联分析变得越来越重要。作为一种强大的数据挖掘工具,它可以帮助企业发现数据之间的关联和模式,从而更好地理解市场和客户的行为。通过关联分析,企业可以发现看似无关的数据之间的联系&…

假如我有一台服务器,我会让它提供三种服务

一、提供照片上传、存储和下载服务 随着移动互联网时代的持续快速发展,PC互联网日益势微,各大互联网门户网站的博客、空间也跟着凋零, 作为博客、空间的标配功能的相册也随之被关闭。 2019年3月6日网易相册发布停运公告并于当年5月8日正式停…

在线主动学习算法评估策略:prequential evaluation procedure

在线主动学习算法评估策略:prequential evaluation procedure 在在线主动学习领域(Online Active Learning),对在线主动学习算法的评估策略有多种方法,而现如今常用的方法是prequential evaluation procedure(出自论文《High density-focuse…

SpringBoot 源码分析(四) 内置Tomcat分析

一、Tomcat相关知识 1. tomcat目录结构 Tomcat文件的目录结构 2.启动流程 启动一个Tomcat服务是执行的bin目录下的脚本程序,startup.bat和 startup.sh.一个是windows的脚本,一个是Linux下的脚本,同样还可以看到两个停止的脚本 shutdown.ba…

Java入门与实践

Java基础 Java入门 idea的使用 idea快捷键 crtlaltt 对选中的代码弹出环绕选项弹出层 问题描述:idea光标变小黑块 解决:误触Insert键,再次按Insert键即可 java基础语法 注释 //单行注释/* 多行注释 *//** 文档注释,可提取到…

车载网关产品解析(附:车载网关详细应用案例及部署流程)

5G车载网关是一款功能强大的工业级无线通讯设备。它集成了4G/5G双模网络模块、M12接口设计、强大的路由和安全功能等特性,可以为车载和移动应用提供稳定可靠的无线数据连接。 链接直达:https://www.key-iot.com/iotlist/sv900.html ### 产品特性 5G车载网关最大的…

【多线程】线程互斥 {多执行流并发执行的数据竞争问题,互斥锁的基本用法,pthread_mutex系列函数,互斥锁的原理;死锁;可重入函数和线程安全}

一、进程线程间通信的相关概念 临界资源:多线程执行流共享的资源就叫做临界资源。确切的说,临界资源在同一时刻只能被一个执行流访问。临界区:每个线程内部,访问临界资源的代码,就叫做临界区。互斥:通过互…

计算机网络基础三

课程目标 理解路由表的作用 能够读懂路由表信息 能够使用图形抓包工具 wireshark 进行数据包的抓取 ,如( TCP/IP 的三次握手四次断开) 一、路由表 思考: 什么是交换,什么是路由,什么是路由表?1. 交换是指同网络访…

Linux C语言开发-D15一维数组

数组&#xff1a;有一定顺序关系的数据类型相同变量的变量集合 形式&#xff1a;<存储类型> <数据类型> <数组名> [<表达式>] 数组名表示内存首地址&#xff0c;是一个地址常量&#xff0c;sizeof(数组名)是数组占用的总内存空间 编译时分配连续内存…

常见的22个软件测试面试题(含答案解析)

大家好&#xff0c;我是大圣。今天大圣给大家列举了API测试的22个面试题&#xff0c;快来看看吧。 1、什么是API? API是允许两个应用程序相互通信的代码。API使开发人员能够发出特定的调用或请求来发送或接收信息。 2、什么是以API为中心的应用程序? 以API为中心的应用程…

重置 VCSA 6.7 root密码和SSO密码

原贴地址&#xff1a;https://www.cnblogs.com/airoot/p/16059033.html 问题描述 1、用root用户登录 VMware vCenter Server Appliance虚拟机失败&#xff0c;无法登录 2、vCenter Server Appliance 6.7 U1的root帐户错误尝试次数超过3次已锁定或帐户已过期 官方说明 在VC…

帆软同时查看多个tab会卡换种方式用网页跳转就会提升效率

效果如图&#xff1a; 方法&#xff1a; 首先&#xff0c;要下载个插件–网页框控件&#xff1b; 接着&#xff0c;做个frm作为首页&#xff0c; 把地址和参数输入进去 最后&#xff0c;预览首页就可以了

【软件教程】如何用C++检查TCP或UDP端口是否被占用

一、检查步骤 使用socket函数创建socket_fd套接字。使用sockaddr_in结构体配置协议和端口号。使用bind函数尝试与端口进行绑定&#xff0c;成功返回0表示未被占用&#xff0c;失败返回-1表示已被占用。 二、CODE 其中port需要修改为想要检测的端口号&#xff0c;也可以将代码…

检测和缓解SQL注入攻击

SQL注入即是指web应用程序对用户输入数据的合法性没有判断或过滤不严&#xff0c;攻击者可以在web应用程序中事先定义好的查询语句的结尾上添加额外的SQL语句&#xff0c;在管理员不知情的情况下实现非法操作&#xff0c;以此来实现欺骗数据库服务器执行非授权的任意查询&#…

Jetpack Compose | State状态管理及界面刷新

我们知道Jetpack Compose&#xff08;以下简称Compose&#xff09;中的 UI 可组合项是通过Composable 声明的函数来描述的&#xff0c;如&#xff1a; Composable fun Greeting() {Text(text "init",color Color.Red,modifier Modifier.fillMaxWidth()) }上面的代…

研究人员发现基于xmpp的即时通讯服务被窃听

攻击者使用我们的加密服务发布了几个新的TLS证书,这些服务被用来劫持加密的 星连接 在5222端口使用透明的[中间人]代理。 到目前为止收集到的证据指向在托管提供者网络上配置的流量重定向,排除了其他可能性&#xff0c;例如服务器中断或欺骗攻击。 据估计&#xff0c;窃听从20…