详解TCP和UDP数据包以及连接过程

2024-08-22 19:38

本文主要是介绍详解TCP和UDP数据包以及连接过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TCP和UDP都输入TCP/IP协议族,是我们常用的两个协议,它们工作在网络层。下面我们来分别来详细讲解TCP和UDP这两个协议。


TCP协议

TCP是面向连接的,可靠的进程到进程通信的协议。TCP提供全双工服务,即数据可在同一时间双向传输,每个TCP都具有发送缓存和接受缓存,用来临时存储数据。

1、TCP报文段

TCP将若干个字节构成一个分组,叫做报文段,TCP报文段封装在IP数据包中。其中IP首部的内容很复杂也很难理解,我们通过下面一张图来详细介绍IP首部的信息。

首部长度为20~60字节,一下是各字段的含义。

源端口号:16位字段,为发送方进程对应的端口号。

目标端口号:16位字段,为接方进程对应的端口号。

序号:32位字段,发送端为每个字节进行编号,便于接收端正确重组。

确认号:32位字段,用于确认发送端的信息。

首部长度:用它可以确定首部数据结构的字节长度。一般情况下TCP是20字节,最大可扩张至60字节。

保留:作为以后扩展功能使用。

URG:紧急指针有效位。

ACK:当ACK=1时,确认序列号字段有效。ACK=0时,确认序列无效。

PSH:标志位为1时要求接受方尽快将数据送达应用层。

PST:当PST值为1时通知重新建立TCP连接。

SYN:同步序号位,TCP需要建立连接时将这个值设为1。

FIN:当FIN值为1时,表示请求断开连接。

窗口大小:它说明本地可接受数据段的数目,这个值是可变的,当网络通畅时将这个窗口值变大可加快传输速度,如果网络不稳定减少这个值可以保证网络数据的稳定性。

校验和:它是用来做差错控制的,与IP的校验和不同,TCP校验和的计算包括TCP首部,数据和其他填充字节。

紧急指针:和URG配合使用,当URG为1时有效。

选项:在TCP首部可以有多达40字节的可选信息。

2、TCP的连接过程

TCP是面向连接的协议,它在源点和终点之间建立一条虚连接。在数据通信之前,发送端与接收端要先建立连接。等数据发送结束后,双发再断开连接。TCP连接的每一方都是由一个IP地址和一个端口号组成。TCP建立连接的过程称为三次握手。如下图:详细介绍TCP的连接过程。

第一次握手:PC1使用一个随机的端口号向PC2的指定端口发送建立连接的请求,此过程的典型标志是TCP的SYN为1,其余都为0。

第二次握手:PC2收到PC1的请求,向PC1回复一个确认加请求的信息,此过程的典型标志是TCP的ACK控制位为1,确认序列号是PC1的初始序列号加1,SYN为1。

第三次握手:PC1收到PC2的回复(包含请求和确认),也向PC2回复确认信息,此过程的典型标志就是TCP的ACK为1,而且确认序列号是PC2的初始序列号加1。

TCP使用面向连接的通信方式,这大大提高了数据传输的可靠性,是发送端和接收端在数据正式传输之前就有了交互,为数据正式传输打下了可靠的基础。

3、TCP的连接断开过程

参加交换数据的双方中的任何一方都可以关闭连接。TCP断开连接分四步,也称为四次断开。如下图:详细解释TCP的断开过程。

第一次:PC1向PC2发送FIN和ACK为1的报文段。

第二次:PC2向PC1回复确认信息,即ACK为1。

第三次:PC2向PC1发送FIN和ACK为1的报文段。

第四次:PC1向PC2回复确认信息,即ACK为1。

在TCP断开的过程中,有一个半关闭的概念。TCP一方可以终止发送数据,但仍可以接受数据,这称作半关闭。具体描述如下:

PC2发送FIN报文段,半关闭了这个链接,PC1发送ACK确认接受半关闭。

PC1继续发送数据,而客户端只发送ACK确认,不再发送任何数据。

当PC1已经把所有数据发送完毕时,就发送FIN报文段,PC2在发送ACK的确认信息,端口链接。


UDP协议

UDP是一个无连接,不保证可靠性的传输层协议,也就是说发送端部关心发送的数据是否到达目标主机,数据是否出错等,收到数据的主机也不会告诉发送方是否收到了数据,它的可靠性有上层协议来保障。

那么UDP这么不安全为什么我们还要使用UDP呢?

因为UDP的报文很段,发送速度很快,在一些不需要安全性的情况下可以使用UDP协议。比喻:一些常见聊天工具,如QQ等都使用UDP协议传输聊天记录的。

UDP首部格式如下图所示:

源端口号:用来标示数据发送端的端口号。

目地端口:用来标示数据接收端的端口号。

UDP长度:用来支出UDP的总长度,为首部加上数据。

校验和:用来完成对UDP数据的差错检验,这时UDP协议提供的唯一的可靠机制。


UDP的连接和断开的过程就不用在说了,因为UDP的连接和断开太简单了。




本文出自 “邓奇的Blog” 博客,请务必保留此出处http://dengqi.blog.51cto.com/5685776/1257047

这篇关于详解TCP和UDP数据包以及连接过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097204

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.