【计算机网络】Layer4-Transport layer

news2024/12/18 4:31:47

目录

  • 传输层协议
    • How demultiplexing works in transport layer(传输层如何进行分用)
      • 分用(Demultiplexing)的定义:
      • TCP/UDP段格式:
  • UDP
    • UDP的特点:
    • UDP Format
    • 端口号
    • Trivial File Transfer Protocol (TFTP)
    • File Transfer Protocol (FTP)
      • FTP Replies
  • TCP
    • TCP简介:
    • TCP的特性:
    • 端口号的作用:
    • TCP Header Fields(TCP头部字段)
    • Connection-Oriented Demultiplexing
      • TCP套接字通过**四元组(4-tuple)**唯一标识:
    • TCP Connection Establishment & Termination TCP连接的建立与终止
      • 连接建立
      • 连接终止:
    • TCP状态图
      • 客户端
      • 服务器端
    • TCP Timers(TCP定时器)
      • TCP定时器的作用:
    • Selective Acknowledgement(选择性确认)
      • SACK(选择性确认)的用途:
      • 实现方式:
    • TCP Congestion Control Parameters(TCP拥塞控制参数)
      • 主要参数:
  • Streaming Multimedia: UDP or TCP?
    • UDP 特性:
    • TCP 特性:
  • HTTP Adaptive Streaming (HAS)
    • HAS 的特点:
    • 常见变体:
    • HAS 的分段传输机制:

传输层协议

传输层协议是端到端的协议。仅在主机上实现。
两种常见的传输层协议:

  • UDP

    • 面向数据报(Datagram oriented):基于数据报的传输方式,不建立连接。
    • 不可靠,无连接(Unreliable, connectionless):不保证数据的可靠性,也没有连接建立过程。
    • 简单(Simple):协议设计较为轻量化,开销小。
    • 支持单播和多播(Unicast and multicast):适合多种网络通信场景。
    • 常用于网络控制信令服务:
      • 如网络管理(SNMP)、路由(RIP)、域名解析(DNS)等。
    • 适用于交互式多媒体应用:
      • 如视频流、音频流等需要快速传输的场景。
  • TCP

    • 面向流(Stream oriented):数据以字节流的形式传输。
    • 可靠,面向连接(Reliable, connection-oriented):通过握手机制建立连接,确保数据可靠传输。
    • 复杂(Complex):实现了流量控制、拥塞控制等功能。
    • 仅支持单播(Unicast only):只支持点对点通信。
    • 广泛用于大多数互联网应用:
      • 如网页(HTTP)、邮件(SMTP)、文件传输(FTP)、终端(Telnet)等。
    • 许多基于HTTP/TCP的应用程序依赖它。

How demultiplexing works in transport layer(传输层如何进行分用)

分用(Demultiplexing)的定义:

分用是传输层的重要功能,用于将接收到的IP数据报分发到正确的应用程序(或套接字)。
具体分用过程:

主机接收到IP数据报,其中包含:

  • 源IP地址和目标IP地址(来自网络层)。
  • 源端口号和目标端口号(来自传输层)。

每个数据报包含一个传输层段(TCP或UDP段)。
传输层通过IP地址和端口号将数据分配到正确的套接字(socket)。

TCP/UDP段格式:

在这里插入图片描述

UDP

UDP的特点:

  • 不可靠传输:UDP不会确认数据是否正确到达。
  • 功能简单:
    • 基本功能是将IP数据报的主机到主机传递扩展为应用程序到应用程序的传递。
  • UDP的主要附加功能是多路复用(multiplexing)和分用(demultiplexing)。
  • UDP的传输过程:
    • 应用程序通过UDP协议向目标发送数据报。
    • IP层负责数据报的路由和传递。
    • 接收主机的UDP层根据端口号将数据分发到目标应用程序。

UDP Format

在这里插入图片描述

端口号

  • 动态/私有端口(Dynamic/private ports):
    • 范围:49152-65535。
    • 供客户端随机选择使用。
  • 注册端口(Registered ports):
    • 范围:1024-49151。
    • 普通用户进程使用。
  • 知名端口(Well-known ports):
    • 范围:0-1023。
    • 保留给系统或服务器使用,例如HTTP(80端口)和DNS(53端口)。

Trivial File Transfer Protocol (TFTP)

  • TFTP会话过程:

    • 客户端通过UDP端口69向服务器发送读/写请求(RRQ/WRQ)。
    • 如果是读请求,服务器返回一个长度为512字节的数据包,编号为1。
    • 客户端发送ACK,确认收到数据块1。
    • 服务器发送下一个数据块2。
    • 重复以上步骤,直到最后一个数据块的长度小于512字节,传输结束。
  • TFTP数据包结构:

    • opcode:操作码(读、写、数据、ACK等)。
    • block number:数据块编号。
    • data:数据字段,最大长度512字节。

File Transfer Protocol (FTP)

  • 连接类型:
    • 控制连接:
      • 服务器的控制端口为21。
      • 用于发送命令和响应。
    • 数据连接:
      • 服务器的数据端口为20。
      • 用于传输文件数据。

在这里插入图片描述

FTP Replies

Typical FTP replies
● 125 Data connection already open; transfer starting
● 200 Command OK
● 331 Username OK, password required
● 425 Can’t open data connection
● 452 Error writing file
● 500 Syntax error (unrecognized command)
● 501 Syntax error (invalid arguments

TCP

TCP简介:

  • TCP是传输层的另一个主要协议,与UDP相比,TCP提供可靠的、面向连接的服务。
    常用于需要高可靠性的应用,例如HTTP、FTP、Telnet等。

TCP的特性:

  • 可靠性:
    提供错误控制、确认机制和数据重传功能。
  • 流量控制:
    基于接收方缓冲区的反馈,动态调整发送速度。
  • 拥塞控制:
    根据网络的拥塞状态调整数据传输速率。

端口号的作用:

源端口号和目标端口号用于唯一标识发送方和接收方的套接字。

TCP Header Fields(TCP头部字段)

  • 源端口号(Source Port Number):
    标识发送方应用程序。
  • 目标端口号(Destination Port Number):
    标识接收方应用程序。
  • 序列号(Sequence Number):
    标识数据段在整个传输流中的位置,用于数据重组。
  • 确认号(Acknowledgment Number):
    用于确认接收到的数据段。
  • 窗口大小(Window Size):
    表示接收方允许的最大数据量,用于流量控制。
  • 校验和(Checksum):
    用于检测TCP头部和数据是否有错误。

Connection-Oriented Demultiplexing

TCP套接字通过**四元组(4-tuple)**唯一标识:

  • 源IP地址。
  • 源端口号。
  • 目标IP地址。
  • 目标端口号。

TCP Connection Establishment & Termination TCP连接的建立与终止

连接建立

使用三次握手(Three-Way Handshake):

  1. 客户端发送SYN。
  2. 服务器返回SYN-ACK。
  3. 客户端发送ACK,连接建立成功

连接终止:

使用四次挥手(Four-Way Handshake):

  1. 一方发送FIN,表示完成数据发送。
  2. 另一方发送ACK确认。
  3. 第二方发送FIN。
  4. 第一方发送ACK,连接终止。

TCP状态图

客户端

  1. CLOSED:初始状态,客户端准备建立连接。
  2. SYN_SENT:客户端发送SYN,等待服务器响应。
  3. ESTABLISHED:三次握手完成,连接建立。
  4. FIN_WAIT_1:客户端发送FIN,启动关闭过程。
  5. FIN_WAIT_2:客户端等待对方发送FIN。
  6. TIME_WAIT:客户端发送ACK后进入等待状态,确保数据可靠传输。

在这里插入图片描述

服务器端

  1. CLOSED:服务器未开启。
  2. LISTEN:服务器等待客户端连接。
  3. SYN_RCVD:收到客户端SYN,发送SYN-ACK。
  4. ESTABLISHED:三次握手完成,进入数据传输状态。
  5. CLOSE_WAIT:收到客户端的FIN,等待应用程序关闭。
  6. LAST_ACK:发送FIN并等待客户端的ACK。
    CLOSED:连接完全关闭。

在这里插入图片描述

TCP Timers(TCP定时器)

TCP定时器的作用:

  • 连接建立定时器(Connection Establishment Timer):
    控制建立连接的最大时间。
  • 重传定时器(Retransmission Timer):
    如果数据段未被确认,则重传。
  • 延迟ACK定时器(Delayed ACK Timer):
    在交互式数据流中延迟ACK以提高效率。
  • 保持活动定时器(Keepalive Timer):
    检查连接是否仍然存活。
  • 坚持定时器(Persist Timer):
    在接收窗口为零时避免死锁,周期性地探测窗口大小。
    使用指数回退算法(Exponential Backoff)。
  • TIME_WAIT定时器:
    在连接关闭后保持一段时间,防止旧的延迟数据段被误解为新连接的一部分

Selective Acknowledgement(选择性确认)

SACK(选择性确认)的用途:

在TCP中,如果接收方发现多个数据段丢失,可以使用SACK选项通知发送方哪些数据段已成功接收。
SACK允许发送方仅重传丢失的数据段,而不是重传整个窗口的数据,从而提高效率。

实现方式:

TCP的SACK功能通过两个选项实现:

  • SACK-Permitted:连接建立时协商是否允许使用SACK。
  • SACK Option:在数据传输中实际使用,提供丢失和接收数据段的信息。

TCP Congestion Control Parameters(TCP拥塞控制参数)

主要参数:

  • 广告窗口大小(rwnd):
    接收方通知发送方的缓冲区可用空间。
  • 最大分段大小(MSS):
    每个TCP数据段的最大字节数。
  • 拥塞窗口(cwnd):
    发送方根据网络状况调整的窗口大小。
  • 慢启动阈值(ssthresh):
    用于分界慢启动和拥塞避免的阈值。

Streaming Multimedia: UDP or TCP?

UDP 特性:

  • 发送速率固定,忽略网络拥塞。
  • 播放延迟短(2-5秒),以补偿网络延迟抖动。
  • 错误恢复能力弱:丢包可能导致数据损失。
  • 典型应用:多媒体服务(如交互式应用)。

TCP 特性:

  • 不适用于多播,但适用于单播。
  • 通过拥塞控制调节速率,但可能导致波动。
  • 播放延迟较大,但能提高可靠性。
  • 支持穿越防火墙。
  • 典型应用:与 HTTP 结合的流媒体服务。

HTTP Adaptive Streaming (HAS)

HAS 的特点:

  • 基于 TCP 实现,具备高可靠性。
  • 与现有 Web 技术集成:能利用 HTTP,适配现有网络基础设施。
  • 自动适应可用带宽。
  • 标准化支持(如 MPEG-DASH)。

常见变体:

  • Microsoft Silverlight
  • Apple HLS
    选择比特率:根据当前和先前下载速率动态调整每段视频的比特率。

HAS 的分段传输机制:

  • 视频分片:视频文件被划分为2-10秒的视频片段。
  • 多码率编码:每个片段被编码为多个可选比特率。
  • Manifest 文件:
    • 提供可供客户端选择的比特率列表。
  • 客户端算法:
    • 起始选择较低的比特率。
    • 根据传输时间动态调整比特率。
    • 尝试维持播放缓冲区的正常水位。

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

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

相关文章

【Excel】单元格分列

目录 分列(新手友好) 1. 选中需要分列的单元格后,选择 【数据】选项卡下的【分列】功能。 2. 按照分列向导提示选择适合的分列方式。 3. 分好就是这个样子 智能分列(进阶) 高级分列 Tips: 新手推荐基…

易语言鼠标轨迹算法(游戏防检测算法)

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言,原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势: 模拟…

.net winform 实现CSS3.0 泼墨画效果

效果图 代码 private unsafe void BlendImages1(Bitmap img1, Bitmap img2) {// 确定两个图像的重叠区域Rectangle rect new Rectangle(0, 0,Math.Min(img1.Width, img2.Width),Math.Min(img1.Height, img2.Height));// 创建输出图像,尺寸为重叠区域大小Bitmap b…

Https身份鉴权(小迪网络安全笔记~

附:完整笔记目录~ ps:本人小白,笔记均在个人理解基础上整理,若有错误欢迎指正! 5.2 Https&身份鉴权 引子:上一篇主要对Http数据包结构、内容做了介绍,本篇则聊聊Https、身份鉴权等技术。 …

7.OPEN SQL

总学习目录请点击下面连接 SAP ABAP开发从0到入职,冷冬备战-CSDN博客 目录 ​编辑 1.OPEN-SQL 简单回顾 R3体系 OEPN-SQL 2.OPEN-SQL 读取数据 2.1Select 语句 select 1条数据 多条数据与into AS别名 2.2INTO 结构体 内表 例子 2.3FROM 选择动态表…

PLC网关,plc远程通信 —— 跨越距离远程控制运维升级

在日新月异的工业4.0时代,智能化、网络化已成为制造业转型升级的关键词。其中,PLC(可编程逻辑控制器)作为工业自动化控制的核心设备,其远程通信技术的突破,正引领着一场前所未有的工业变革。今天&#xff0…

Python-基于Pygame的小游戏(天空之战)(一)

前言:不久前接触了Python的游戏制作的相关第三方库,于是学习了pygame的相关内容,想制作一款基于pygame的小游戏。因为还不太熟悉游戏制作和pygame,部分内容我参考了《Python-从入门到精通》这本书。那么好,话不多说,我…

CV(4)--边缘提取和相机模型

前言 仅记录学习过程,有问题欢迎讨论 边缘提取(涉及语义分割): 图象的边缘是指图象局部区域亮度变化显著的部分,也有正负之分,暗到亮为正 求边缘的幅度:sobel,Canny算子 图像分高频分量和低…

cocos creator 的 widget组件的使用及踩坑

以下的内容基于cocos creator 3.8版本,如有错误,恳请指出。 👉官方文档的指引 应用:以上官方指引有非常清晰的使用方式,接下来说明一些注意事项: 1、与canvas搭配的使用,解决多分别率适配问题。…

九个任务调度框架

一、背景介绍 说到定时任务,相信大家都不陌生,在我们实际的工作中,用到定时任务的场景可以说非常的多,例如: 双 11 的 0 点,定时开启秒杀每月1号,财务系统自动拉取每个人的绩效工资&#xff0…

Qt6开发自签名证书的https代理服务器

目标:制作一个具备类似Fiddler、Burpsuit、Wireshark的https协议代理抓包功能,但是集成到自己的app内,这样无需修改系统代理设置,使用QWebengineview通过自建的代理服务器,即可实现https包的实时监测、注入等自定义功能…

【深度学习项目】目标检测之YOLO系列详解(一)

介绍 YOLO(You Only Look Once)是一种实时目标检测算法,由Joseph Redmon等人提出。与传统的基于滑动窗口和区域提案的目标检测方法不同,YOLO将目标检测问题框架化为一个单一的回归问题,直接从图像像素预测边界框和类别…

SpringBoot + minio + kkfile 实现文件预览

1、容器安装kkfileviewer 1.1 下载文件 这里以kkfile 4.4.0-beta版本为例 下载kkfile安装包及Dockerfile: https://codeup.aliyun.com/6254dee9a923b68581caaf50/kkfileviewer.git 1.2、构建镜像 git clone https://codeup.aliyun.com/6254dee9a923b68581caaf50…

HCIE之OSPF基础(十九)

OSPF理论 一、OSPF基本原理(回顾)1. 邻居建立1.1(411)HELLO包影响邻居建立的因素。1.2 其它影响邻居建立的因素:1.3 基本配置1.4 验证命令 2 DR选举2.1 为什么选?2.2 在哪选?2.3 怎么选&#xf…

python 基于 docx 文件模板生成 docx 或 PDF 文件

需求背景 提供一个Word文档模板,使用python程序替换里边的占位符,替换内容包括文本和图片,然后输出docx或者PDF文件。 功能演示 输入示例 输出示例 实现程序 import os import shutil import subprocess import timefrom docx import Doc…

CSS 实现带tooltip的slider

现代 CSS 强大的令人难以置信 这次我们来用 CSS 实现一个全功能的滑动输入器,也就是各大组件库都有的slider,效果如下 还可以改变一下样式,像这样 特别是在拖动时,tooltip还能跟随拖动的方向和速度呈现不同的倾斜角度&#xff0c…

MybatisPlus-扩展功能

代码生成 在使用MybatisPlus以后,基础的Mapper、Service、PO代码相对固定,重复编写也比较麻烦。因此MybatisPlus官方提供了代码生成器根据数据库表结构生成PO、Mapper、Service等相关代码。只不过代码生成器同样要编码使用,也很麻烦。 这里…

中后台管理信息系统:Axure12套高效原型设计框架模板全解析

中后台管理信息系统作为企业内部管理的核心支撑,其设计与实现对于提升企业的运营效率与决策能力具有至关重要的作用。为了满足多样化的中后台管理系统开发需求,一套全面、灵活的原型设计方案显得尤为重要。本文将深入探讨中后台管理信息系统通用原型方案…

40 基于单片机的温湿度检测判断系统

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于STC89C52单片机,采用dht11温湿度传感器检测温湿度, 通过lcd1602显示屏各个参数,四个按键分别可以增加温湿度的阈值, 如果超过阈值,则…

SAP ABAP-日期格式问题 SAP内部错误,反序列化JSON字符串时发生异常 值 20241215 不是根据 ABAP 的 XML 格式的有效日期

SAP ABAP-日期格式问题 SAP内部错误,反序列化JSON字符串时发生异常 值 20241215 不是根据 ABAP 的 XML 格式的有效日期 在SAP内部用 YYYYMMDD没有问题 外部传入参数