计算机网络(五)传输层

传输层

从通信和信息处理的角度看,传输层向它上面的应用层提供通信服务,属于面向通信部分的最高层,同时也是用户功能中的最低层

传输层功能

  1. 传输层提供应用进程之间的逻辑通信(即端到端的通信)。与网络层的区别区别是,网络层提供的是主机之间的逻辑通信
  2. 传输层可以实现多路复用和多路分解的功能,使得多个应用程序可以共享同一个网络连接。它通过使用端口号来区分不同的应用程序,并将数据传输到相应的应用程序中
  3. 传输层负责将上层应用层传输的数据分段,并在目标主机上将这些数据段重新组装成完整的数据。这个过程称为分段和重组
  4. 传输层可以对传输过程中可能出现的错误进行检测和纠正,以确保数据的完整性和准确性。它通过使用校验和等技术来检测传输过程中的错误,并采取相应的措施进行纠正

传输层的端口

端口的作用

端口能让应用层的各种应用进程将其数据通过端口向下交付给传输层

传输层的SAP(Service Access Point)是端口,网络层的SAP是IP地址,数据链路层的SAP是MAC地址

在协议栈层间的抽象的协议端口是软件端口,它与路由器或交换机上的硬件端口是完全不同的概念

硬件端口是不同硬件设备进行交互的接口,软件端口则是应用层的各种协议进程与传输实体进行层间交互的一种地址,传输层使用的是软件端口

端口号

端口号是一种用于标识计算机网络中应用程序或服务的数字标识

端口号范围从0到65535,其中0到1023是被保留的系统端口号,用于一些常见的服务,而1024到65535是动态或私有端口号,用于分配给应用程序或服务

套接字

套接字(Socket)是计算机网络中用于实现网络通信的一种机制,它是传输层和应用层之间的接口。套接字允许应用程序通过网络发送和接收数据,并提供了一种通用的编程接口,使得应用程序可以独立于底层网络协议来实现网络通信

所谓套接字,实际上是一个通信端点

套接字 = (主机IP地址, 端口号)

无连接服务

无连接服务是指在通信双方之间发送数据时,不需要事先建立连接的通信方式。每个数据包都是独立发送的,发送者不需要等待接收者的响应,也不需要维护连接状态

面向连接服务

面向连接服务是指在通信双方之间发送数据之前,需要先建立连接并维护连接状态。在连接建立之后,通信双方可以进行可靠的、面向流的数据传输,并且可以保证数据的顺序和完整性

UDP

概述

  1. 无连接性:UDP是一种无连接的协议,通信双方之间不需要建立连接就可以直接发送数据。每个UDP数据包都是独立的,发送者不需要等待接收者的确认或响应
  2. 不可靠性:UDP不保证数据的可靠传输,数据包可能会丢失、重复、延迟或乱序到达。UDP不提供重传机制、流量控制或拥塞控制,因此不能保证数据的完整性和顺序性
  3. 简单性:UDP协议相比于TCP协议更加简单,因为它不需要建立连接、维护连接状态或进行流量控制。UDP的头部信息也相对较小,只包含源端口号、目标端口号、长度和校验和等字段
  4. 高效性:由于不需要进行连接的建立和维护,以及不需要进行重传和流量控制,UDP协议的传输效率相对较高。它适用于一些对传输延迟要求较高的实时应用,如音视频通信、在线游戏等

UDP的首部格式

 0      7 8     15 16    23 24    31
+--------+--------+--------+--------+
|     源端口号      |   目的端口号    |
+--------+--------+--------+--------+
|       长度        |     校验和      |
+--------+--------+--------+--------+
|                                     |
|              数据(可选)             |
|                                     |
+--------+--------+--------+--------+
  1. 源端口号(16比特):指示数据报的发送者端口号

  2. 目的端口号(16比特):指示数据报的接收者端口号

  3. 长度(16比特):指示UDP数据报(包括首部和数据)的总长度,以字节为单位。长度字段的最小值为8字节(UDP首部的长度),最大值为65535字节

  4. 校验和(16比特):用于对UDP数据报进行校验的校验和字段。校验和的计算方式涉及UDP首部和数据报的内容

  5. 数据(可选):包含实际的应用数据。数据字段的长度可以为0,表示UDP数据报不携带任何应用数据

UDP校验

UDP校验和是一种简单的差错检测机制,用于检测UDP数据报在传输过程中是否发生了错误或损坏。UDP校验和的计算方法基于数据报的所有内容,包括UDP首部和数据字段

过程

  1. 将UDP首部和数据字段划分为若干个16比特的字(如果数据字段的长度不是16比特的整数倍,则在末尾补零)

  2. 将这些16比特的字两两相加,得到一个16比特的中间结果

  3. 将所有的16比特的中间结果相加,直到得到一个32比特的累加和

  4. 取累加和的反码作为校验和

在接收端,接收到UDP数据报后会重新计算校验和,并与接收到的校验和进行比较,以确定数据报是否损坏或错误。如果校验和匹配,则认为数据报未损坏;如果校验和不匹配,则认为数据报可能已损坏,并丢弃该数据报

TCP

TCP报文段

在这里插入图片描述

  1. 源端口号(16比特):发送端口号,表示数据发送方的端口号

  2. 目的端口号(16比特):接收端口号,表示数据接收方的端口号

  3. 序列号(32比特):用于标识数据流中的每个字节的序号,用于实现数据的顺序传输和可靠传输

  4. 确认号(32比特):用于确认接收到的数据字节的序号,表示期望接收的下一个数据字节的序号

  5. 数据偏移(4比特):指示TCP首部的长度,以32比特字为单位,用于指示TCP报文段的首部长度

  6. 保留(6比特):保留字段,暂时没有使用,用于未来扩展

  7. 控制位(6比特):包含了多个控制标志位,用于控制TCP的各种行为,如SYN、ACK、FIN、RST等

  8. 窗口大小(16比特):用于流量控制,表示发送方期望接收方发送的数据量

  9. 校验和(16比特):用于对TCP首部和数据进行校验的校验和字段

  10. 紧急指针(16比特):用于指示紧急数据的位置

  11. 选项(可选):用于指定一些额外的控制选项,如最大报文段长度、时间戳等

  12. 数据(可选):包含了应用层的数据,是TCP传输的实际数据内容

TCP连接管理

TCP连接

TCP是面向连接的协议,因此每个TCP连接有三个阶段:连接建立、数据传送、连接释放

TCP把连接作为最基本的抽象,每条TCP连接有两个端点,TCP连接的端点不是主机,不是主机的IP地址,不是应用进程,也不是传输层的协议端口,TCP连接的端口称为套接字(socket),端口拼接IP地址构成套接字

在这里插入图片描述

TCP连接的建立采用客户/服务器方式。主动发起连接建立的应用进程称为客户机(Client),而被动等待连接建立的应用进程称为服务器(Server)

过程

  1. 客户机的TCP首先向服务器的TCP发送一个连接请求报文段。这个特殊的报文段中不含应用层数据,其首部中的SYN标志位被置为1。另外,客户机会随机选择一个起始序号seq = x(连接请求报文不携带数据,但要消耗一个序号)
  2. 服务器的TCP收到连接请求报文段后,如同意建立连接,就向客户机发会确认,并位该TCP连接分配TCP缓存和变量。在确认报文段中,SYN和ACK位都被置为1,确认号字段的值位x + 1,并且服务器随机产生起始序号seq = y (确认报文不携带数据,但也要消耗一个序号) 确认报文段同意不包含应用层数据
  3. 当客户机收到确认报文段后,还要向服务器给出确认,并且也要给该连接分配缓存和变量。这个报文段的ACK标志位置1,序号字段为 x + 1,确认号字段 ack = y + 1,该报文段可以携带数据,若不携带数据则不消耗序号
TCP连接的释放

在这里插入图片描述

TCP连接的释放是指在通信双方完成数据传输后,关闭TCP连接的过程。TCP连接的释放过程通常分为四个步骤,即TCP的四次挥手(Four-way Handshake)

  1. 客户端发送FIN报文段:当客户端完成数据传输后,它会向服务端发送一个FIN(结束)报文段,表示客户端不再发送数据,并且请求关闭连接
  2. 服务端发送ACK报文段:服务端接收到客户端的FIN报文段后,会向客户端发送一个ACK(确认)报文段,确认收到了客户端的FIN报文段,但是表示服务端仍然可以发送数据
  3. 服务端发送FIN报文段:当服务端也完成数据传输后,它会向客户端发送一个FIN报文段,表示服务端不再发送数据,并且请求关闭连接
  4. 客户端发送ACK报文段:客户端接收到服务端的FIN报文段后,会向服务端发送一个ACK报文段,确认收到了服务端的FIN报文段,表示双方都准备好关闭连接
服务器:
1. 创建服务器套接字 server_socket
2. 将服务器套接字 server_socket 绑定到指定的 IP 地址和端口
3. 开始监听传入的连接请求(listen)
4. 当有连接请求到达时:1. 接受连接请求并创建一个新的套接字 client_socket2. 从客户端接收数据(recv)3. 处理接收到的数据4. 向客户端发送响应数据(send)5. 关闭 client_socket
5. 关闭服务器套接字 server_socket
客户端:
1. 创建客户端套接字 client_socket
2. 连接到指定的服务器 IP 地址和端口(connect)
3. 向服务器发送数据(send)
4. 接收服务器的响应数据(recv)
5. 处理接收到的数据
6. 关闭客户端套接字 client_socket
TCP可靠传输

TCP(传输控制协议)提供了可靠的数据传输机制,确保数据能够按照正确的顺序、完整地传输到目标主机。TCP的可靠传输主要T通过以下几种机制来实现

  1. 序列号和确认机制:TCP在传输数据时会给每个数据字节分配一个序列号(Sequence Number),用于标识数据流中每个字节的位置。接收端会向发送端发送确认(ACK)报文段,确认收到的最后一个字节的序列号,从而实现对数据的可靠传输
  2. 超时重传机制:TCP在发送数据时会设置一个定时器,等待接收到对应的确认报文段。如果在定时器超时之前没有收到确认报文段,发送端会认为数据丢失或损坏,然后重新发送数据。通过超时重传机制,TCP能够保证数据的可靠传输
  3. 滑动窗口机制:TCP使用滑动窗口机制来进行流量控制和拥塞控制。接收端可以通过发送窗口(Receive Window)来告知发送端自己的可接受数据量,发送端根据接收窗口的大小来调整发送速率。通过滑动窗口机制,TCP能够避免发送方发送过多的数据导致接收方无法及时处理,从而实现流量控制和拥塞控制
    坏,然后重新发送数据。通过超时重传机制,TCP能够保证数据的可靠传输
  4. 滑动窗口机制:TCP使用滑动窗口机制来进行流量控制和拥塞控制。接收端可以通过发送窗口(Receive Window)来告知发送端自己的可接受数据量,发送端根据接收窗口的大小来调整发送速率。通过滑动窗口机制,TCP能够避免发送方发送过多的数据导致接收方无法及时处理,从而实现流量控制和拥塞控制
  5. 重复消除机制:TCP在接收到重复的数据时会进行重复消除,避免重复数据对应用程序造成影响。TCP通过使用序列号和确认号来检测重复的数据,然后丢弃重复的数据,从而确保应用程序只接收到一份正确的数据

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

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

相关文章

SSH客户端工具输入目标地址端口远程失败故障原因和解决方案

问题表现:SSH客户端工具输入目标地址端口远程失败时,出现ssh client 报 algorithm negotiation failed的异常信息。 使用SSH Secure Shell Client连接Linux服务器的SSH的时候有时会出现错误提示信息:ssh algorithm negotiation failed。这是…

ts文件用什么播放器?带您了解TS文件播放器的选择

ts文件用什么播放器?在数字多媒体时代,各种视频文件格式层出不穷,其中TS文件作为一种常见的视频封装格式,广泛应用于高清视频的制作与传输。然而,对于许多用户来说,如何选择合适的播放器来播放TS文件却是一…

Windows电脑使用Everything+cpolar搭建在线资料库并实现无公网IP管理文件

文章目录 推荐前言1.软件安装完成后,打开Everything2.登录cpolar官网 设置空白数据隧道3.将空白数据隧道与本地Everything软件结合起来总结 推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家…

算法——马尔可夫与隐马尔可夫模型

HMM(Hidden Markov Model)是一种统计模型,用来描述一个隐含未知量的马尔可夫过程(马尔可夫过程是一类随机过程,它的原始模型是马尔科夫链),它是结构最简单的动态贝叶斯网,是一种著名…

attention and tell论文【无标题】

这个公式使用LaTeX语法表示为: ( i t f t o t c t ) ( σ σ σ tanh ⁡ ) T D m n , n ( E y t − 1 h t − 1 x t ) \begin{pmatrix}i_t \\f_t \\o_t \\c_t\end{pmatrix} \begin{pmatrix}\sigma \\\sigma \\\sigma \\\tanh\end{pmatrix}T_{Dmn,n}\begin{pmatri…

内外网文件摆渡系统,如何贯通网络两侧被隔断的工作流?

随着业务范围不断扩大,产生的数据体量越来越多,企业会采取网络隔离,对核心数据进行保护。网络隔离主要目的是保护企业内部的敏感数据和系统不受外部网络攻击的风险,可以通过物理或逻辑方式实现,例如使用防火墙、网闸、…

Day13-Python基础学习之数据分析案例

数据分析案例 data_define.py # 数据定义的类 class Record:def __init__(self, date, order_id, money, province):self.date dateself.order_id order_idself.money moneyself.province province ​def __str__(self):return f"{self.date}, {self.order_id}, {se…

数学基础:深度学习的语言

数学基础:深度学习的语言 概述 在深度学习的世界里,数学不仅仅是一套工具,它是构建、理解和优化深度学习模型的基石。从向量空间的概念到复杂的优化算法,数学的每一个分支都在深度学习的发展中扮演着关键角色。本文的目标是通过深…

【前端面试3+1】17 伪类和伪元素的区别、CSS权重、图片显示优化、【二叉树最大深度】

一、伪类和伪元素的区别 1、伪类: 伪类是用来描述元素的特定状态的选择器,比如:hover、:active、:first-child等。伪类在选择器中以冒号(:)开头,用于匹配处于特定状态的元素。伪类可以用于选择DOM元素的特定状态&#…

zabbix解析以及安装

目录 目录 zabbix 是什么? 监控主要功能 zabbix 监控原理: zabbix运行机制 Zabbix的监控方式 Zabbix监控系统监控对象 Zabbix的优缺点 Zabbix的缺点 zabbix主要特点 zabbix 监控部署在系统中,包含常见的五个程序: 监控的架构 3.maste…

vscode和pycharm等idea编写protobuf文件格式化

想在pycharm或者goland等idea中开发protobuf文件的话,可以安装一个插件:protocol-buffers 安装之后,proto文件就会支持高亮和格式化了。 如果是vscode想要编写proto文件,可以安装另外一个插件:vscode-proto3 安装后&a…

“资深主食冻干品鉴家”认证!希喂CPMR2.0鲜肉主食冻干值得入!

作为一名养猫长达十二年的资深铲屎官,自从20年起,我家便步入了全冻干喂养的新纪元。请别误会,我并非什么拆二代,而是因为我找到了一款既让猫咪爱不释手,又在我预算之内的优质主食冻干。市面上的主流品牌,我…

如何解决线程池引发的future性能问题?

背景 在我们的日常开发中肯定会遇到线程池的使用,那么随着jdk8的使用发现,future.get()这个API的使用也很普及了,当然重点不是这个api而是我们在设置线程池参数的时候如果使用自带的四种拒绝策略,那没什么…

网络安全赛事中开源威胁情报的妙用

写在前面 近期参与了一场网络安全赛事,一些题目的解法涉及到开源网络威胁情报,遂对相关题目及涉及到的知识点进行分析。 什么是OSCTI 开源网络威胁情报 (Open-Source Cyber Threat Intelligence,OSCTI)是详细描述针对某个组织网络安全威胁的数据。OSC…

【力扣 Hot100 | 第二天】4.11 无重复字符的最长子串

文章目录 2.无重复字符的最长子串2.1题目2.2解法一:滑动窗口2.2.1解题思路2.2.2代码实现 2.无重复字符的最长子串 2.1题目 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例一: 输入: s "abcabcbb" 输…

从零开始写一个RTSP服务器(三)RTP传输H.264

目录 一、RTP封装1.1 RTP数据结构1.2 源码 二、H.264的RTP打包2.1 H.264格式2.2 H.264的RTP打包方式2.3 H.264 RTP包的时间戳计算2.4 源码 三、H.264 RTP打包的sdp描述四、测试 本篇文章目标,使用vlc打开sdp文件后,可以观看到视频数据 一、RTP封装 1.1 …

2024 CKA 基础操作教程(十三)

题目内容 考点相关内容分析 日志架构 虽然 Kubernetes 没有为集群级日志记录提供原生的解决方案,但是提供了以下几种方式收集容器日志: 使用在每个节点上运行的节点级日志记录代理。 在每个节点上部署一个日志代理,该代理负责收集节点上所有…

传奇 mir2韩国2005年原版代码

传奇 mir2韩国2005年原版代码 参考资料;传奇 mir2韩国2005年原版代码-感谢网虫大神分享_98999NET源码资源网

批量重命名文件名,支持取原文件名中间文字来进行重命名,实现文件重命名自由

在信息爆炸的时代,文件管理和命名显得尤为重要。你是否曾为文件命名而烦恼?是否曾经因为文件名过长、格式不统一、无法快速识别内容而浪费大量时间?今天,我要为大家介绍一款强大而灵活的批量文件重命名工具,它能够帮助…

ardupilot开发 --- 视觉伺服基础理论 篇

TOC 0.参考文献 https://zhuanlan.zhihu.com/p/422634446 基础