计算机网络(五)传输层

news2024/11/29 0:47:56

传输层

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

传输层功能

  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_socket
     2. 从客户端接收数据(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.coloradmin.cn/o/1599121.html

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

相关文章

MySQL 试图

视图功能在 5.0 以后的版本启用 视图是一张虚表。数据表确实包含了具体数据并且保存到硬盘中的实表。视图使用数据检索语句动态生 成的一张虚表。每一次数据服务重启或者系统重启之后,在数据库服务启动期间,会使用创建视图的语 句重新生成视图中的数据&…

揭秘智慧礼品背后的故事

如若不是从事技术行业,在罗列礼品清单时,可能不会想到 “数据”,但幸运的是,我们想到了。如何将AI技术应用到当季一些最受青睐的产品中去,训练数据是这一智能技术的背后动力。很多电子设备或名称中带有“智能”一词的设…

频率域滤波总结

我本来想写在一起的,但是这样的话就没有重点了。分开写更能总结出来问题。这里的步骤5的对称滤波函数确实是(2M-1)x(2N-1)的大小,但是书上还说了如下图所示的问题: 首先第一个问题是乘积的问题,为什么普通的函数乘积也需要填充零?…

【电控笔记6.2】拉式转换与转移函数

概要 laplace:单输入单输出,线性系统 laplace 传递函数 总结

DNS解析实验

一、DNS正向解析实验 准备工作 服务端及客户端都关闭安全软件 [rootserver ~]# setenforce 0 [rootserver ~]# systemctl stop firewalld服务端安装bind软件 [rootserver ~]# yum install bind -y服务端配置静态IP [rootserver ~]# nmcli c modify ens33 ipv4.m…

浅尝一下ECS(Entity Component System)(学习笔记)

参考文章:浅谈Unity ECS(一)Uniy ECS基础概念介绍:面向未来的ECS - 知乎 (zhihu.com) 视频链接:【青幻译制】GDC讲座系列之三 守望先锋的游戏架构和网络代码_哔哩哔哩_bilibili 云风的 BLOG: 浅谈《守望先锋》中的 E…

消息队列和分布式消息队列

文章目录 分析系统现状不足中间件消息队列什么是消息队列?应用场景消息队列的模型为什么不直接传输,而要用消息队列?为什么要用消息队列?消息队列的缺点? 分布式消息队列分布式消息队列的优势?消息队列应用…

PLC远程通信:实现工业自动化的关键技术

在当今高度信息化和自动化的时代,工业领域对于实时数据的准确传输和迅速响应提出了更高要求。而PLC(可编程逻辑控制器)远程通信技术,正是能够实现工业自动化的关键技术之一。 首先,我们需要了解PLC远程通信的原理。PLC作为一种专用计算机控制…

设计模式代码实战-组合模式

1、问题描述 小明所在的公司内部有多个部门,每个部门下可能有不同的子部门或者员工。 请你设计一个组合模式来管理这些部门和员工,实现对公司组织结构的统一操作。部门和员工都具有一个通用的接口,可以获取他们的名称以及展示公司组织结构。…

学习BOM

目录 前言: 1. BOM组成: 1.1Window 对象: 1.1Location 对象: 1.2Navigator 对象: 1.2.1 navigator 对象包含了关于浏览器的信息包括: 1.3History 对象: 1.4常用的history的方法和属性: 1.4Document…

氟化钙与盐酸反应

结论:可以反应 参考链接 为什么盐酸,硝酸不能溶解氟化钙呢?氢氟酸可是弱酸啊。。。_百度知道 (baidu.com)https://zhidao.baidu.com/question/421110040.html特此记录 anlog 2024年4月16日

中医圆运动规律

目录 人体圆运动营气在十二经脉的运行规律子午流注与圆运动升降结合图 人体圆运动 营气在十二经脉的运行规律 营气在脉中,卫气在脉外 这个顺序也是子午流注的顺序 子午流注与圆运动升降结合图

【论文阅读02】一种基于双通道的水下图像增强卷积神经网络

来源:海洋论坛▏一种基于双通道的水下图像增强卷积神经网络 当前不会的 一、背景: 水下图像增强方法包含有无水下成像模型的水下图像增强方法、基于水下成像模型的水下图像恢复方法、水下成像模型与深度学习相结合的方法以及完全采用深度学习的方…

数据结构与算法——22.哈希算法

这篇文章我们来讲一下哈希表中较为关键的部分——哈希算法 目录 1.哈希算法的介绍 2.hash算法的使用 2.1 Object.hashCode 2.2 String.hashCode 3.关于哈希表及哈希算法的一些思考 1.哈希算法的介绍 问题:什么是哈希算法?哈希算法有哪些&#xff…

【算法一则】做算法学数据结构 - 简化路径 - 【栈】

目录 题目栈代码题解 题目 给你一个字符串 path ,表示指向某一文件或目录的 Unix 风格 绝对路径 (以 ‘/’ 开头),请你将其转化为更加简洁的规范路径。 在 Unix 风格的文件系统中,一个点(.)表…

兔C_Java集:Java 语言简介

文章目录 1. Java简介历史简介问:Oracle 为什么收购 SUN 公司关于三个分支语言特性: 2. JDK 的安装与配置安装的官网链接配置环境变量 3. 第一个Java程序4. 第一个程序解释关于类的定义 5. CLASSPATH命令自动配置CLASSPATH 与 JVM 的关系CLASSPATH 的手动…

OM3 与 OM4:主要区别和实际应用

OM3 和 OM4 都是激光优化的多模光纤,具有 50/125μm 光纤芯,专为满足 ISO 11801 标准而开发。它们在光纤连接器和应用场景上具有相似性,这往往会导致用户之间的混淆。这些光纤主要设计用于数据中心、局域网 (LAN) 和其…

500以内的不入耳运动耳机推荐,首推五大业内顶级优品

不入耳式运动耳机因其独特的佩戴方式和设计,能够在运动过程中保持对周围环境的警觉,避免因音乐沉浸而忽视潜在的安全隐患,同时它们还能有效减少对耳道的压迫,让运动更加舒适自在,接下来,就让我为大家推荐一…

MAC系统安装PHP、Java、Python、mysql、Composer等环境无权限问题的详细操作方法说明。

本篇文章主要讲解MAC系统安装PHP、Java、Python、mysql、Composer等环境无权限问题的详细操作方法说明。通过本篇文章你可以快速掌握brew安装相对应环境的能力。 作者:任聪聪 日期:2024年4月12日 一、brew介绍及安装说明 官网地址:https://b…

分布式数据库Polardb-X架构及特点

PolarDB-X架构 计算节点(Compute Node,CN)是系统的入口,采用无状态设计的sql引擎提供分布式路由和计算,包括SQL解析器、优化器、执行器等模块。负责数据分布式路由、计算及动态调度,负责分布式事务2PC协调…