详解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

相关文章

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

Java 连接Sql sever 2008

Java 连接Sql sever 2008 /Sql sever 2008 R2 import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class TestJDBC

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |