传输层协议UDP原理

端口号回顾

        端口号的作用类似pid,用来标识进程的唯一性。只是为了与系统解耦,所以有了端口号。

通过ip来确定唯一主机,再通过端口号找到指定的进程。就可以让全网内唯一的两个进程通信了。

        所以一个完整的报文至少要携带ip和端口号,ip是在网络层协议来维护的本章不做讲解,而端口号是在传输层协议中维护的,传输层协议常用的两种:UDP协议和TCP协议,本章将要讲解的是UDP协议,TCP协议在下一期进行讲解。

端口号:2字节(16个比特位)其中:

  • 0 - 1023: 知名端口号, HTTP, FTP, SSH 等这些广为使用的应用层协议, 它们的端口号都是固定的。
  • 1024 - 65535: 操作系统动态分配的端口号. 客户端程序的端口号, 就是由操作系统从这个范围分配的

认识知名端口号
有些服务器是非常常用的, 为了使用方便, 人们约定一些常用的服务器), 都是用以下这些
固定的端口号:

  • ssh 服务器, 使用 22 端口
  • ftp 服务器, 使用 21 端口
  • telnet 服务器, 使用 23 端口
  • http 服务器, 使用 80 端口
  • https 服务器, 使用 443 端口

执行下面的命令, 可以看到知名端口号:

 cat /etc/services

思考:

  1. 一个进程是否可以 bind 多个端口号?
  2. 一个端口号是否可以被多个进程 bind?

        答1:一个进程是可以绑定多个端口号的,当一个进程提供多个不同服务时,就可以通过绑定多个端口来优化。只要一个端口能确定唯一进程就行。

        答2:不能。要保证一个端口确定唯一进程。

UDP协议端格式

  • 16位源端口和16位目的端口用来确定两个唯一进程,这没啥说的。
  • 16位UDP长度:数据字段的大小不是固定的,所以该字段来表示整个数据报(UDP 首部+UDP 数据)的长度。
  • 16位UDP检验和:不保证可靠性,校验和是唯一确定数据是否有效的机制。因为在数据传输过程中物理干扰、路由错误等可能导致数据损坏。

UDP协议特点

  • 无连接: 知道对端的 IP 和端口号就直接进行传输, 不需要建立连接。
  • 不可靠:报文发出去任务就完成了,报文是否丢失不关心。注意这不是缺点,是特点!
  • 面向数据报:发10次,收10次。而TCP协议是面向字节流的,类似自来水。
  • 缓冲区:UDP没有发送缓冲区,直接发(TCP有发送缓冲区是为了方便重传)。有接收缓冲区,出于效率考量,忙的时候,可以缓一缓。缓冲区满了就把报文丢弃。为全双工。

内核源码

UDP协议格式其实就是一个结构体,源码如下:

struct udphdr {unsigned short	src_port;unsigned short	dst_port;unsigned short	len;unsigned short	chksum;
};

        在把数据交付给传输层时,数据在应用层必做序列化和反序列化。当然可直接用结构体变量代替,但非常不推荐(结构体存在内存对齐有内存浪费,与其他语言不兼容,需要考虑字节序问题等等)。

        注:即使通信双方操作系统完全不同,但网络内核部分一定相同(所以能够通信)。操作系统内核都是使用c语言实现。

        在OS内部一定会同时存在大量的报文,而这些报文可分布在各个协议层,OS必须管理这些报文。如果管理?先描述,再组织。如何描述:内核源码中结构体 struct sk_buff,如下:

struct sk_buff 
{struct sk_buff	* next;			/* Next buffer in list 				*/struct sk_buff	* prev;			/* Previous buffer in list 			*/struct sk_buff_head * list;		/* List we are on				*/
#if CONFIG_SKB_CHECKint		magic_debug_cookie;
#endifstruct sk_buff	*link3;			/* Link for IP protocol level buffer chains 	*/struct sock	*sk;			/* Socket we are owned by 			*/unsigned long	when;			/* used to compute rtt's			*/struct timeval	stamp;			/* Time we arrived				*/struct device	*dev;			/* Device we arrived on/are leaving by		*/union {struct tcphdr	*th;struct ethhdr	*eth;struct iphdr	*iph;struct udphdr	*uh;unsigned char	*raw;/* for passing file handles in a unix domain socket */void *filp;} h;union {	/* As yet incomplete physical layer views */unsigned char 	*raw;struct ethhdr	*ethernet;} mac;struct iphdr	*ip_hdr;		/* For IPPROTO_RAW 				*/unsigned long 	len;			/* Length of actual data			*/unsigned long	csum;			/* Checksum 					*/__u32		saddr;			/* IP source address				*/__u32		daddr;			/* IP target address				*/__u32		raddr;			/* IP next hop address				*/__u32		seq;			/* TCP sequence number				*/__u32		end_seq;		/* seq [+ fin] [+ syn] + datalen		*/__u32		ack_seq;		/* TCP ack sequence number			*/unsigned char	proto_priv[16];	        /* Protocol private data			*/volatile char 	acked,			/* Are we acked ?				*/used,			/* Are we in use ?				*/free,			/* How to free this buffer			*/arp;			/* Has IP/ARP resolution finished		*/unsigned char	tries,			/* Times tried					*/lock,			/* Are we locked ?				*/localroute,		/* Local routing asserted for this frame	*/pkt_type,		/* Packet class					*/pkt_bridged,		/* Tracker for bridging 			*/ip_summed;		/* Driver fed us an IP checksum			*/
#define PACKET_HOST		0		/* To us					*/
#define PACKET_BROADCAST	1		/* To all					*/
#define PACKET_MULTICAST	2		/* To group					*/
#define PACKET_OTHERHOST	3		/* To someone else 				*/unsigned short	users;			/* User count - see datagram.c,tcp.c 		*/unsigned short	protocol;		/* Packet protocol from driver. 		*/unsigned short	truesize;		/* Buffer size 					*/atomic_t	count;			/* reference count				*/struct sk_buff	*data_skb;		/* Link to the actual data skb			*/unsigned char	*head;			/* Head of buffer 				*/unsigned char	*data;			/* Data head pointer				*/unsigned char	*tail;			/* Tail pointer					*/unsigned char 	*end;			/* End pointer					*/void 		(*destructor)(struct sk_buff *);	/* Destruct function		*/__u16		redirport;		/* Redirect port				*/
};

封包和解包的本质理解

在以上源码中我们主要关注两个部分:

该字段说明报文用了链表结构来维护,对报文进行操作的本质就是链表的增删改查。

怎么体现不同协议层报文呢?如下字段:

变量指向位置功能
head缓冲区的起始地址指向整个数据包内存的头部(包括预留的“头空间”)。
data当前协议层头部随着协议栈处理,动态移动:
接收时:从MAC头 → IP头 → TCP(或UDP)头 → 应用数据。
发送时:反向移动。
tail当前有效数据的末尾标识实际数据的结束位置(如应用层数据的末尾)。
end缓冲区的结束地址指向整个数据包内存的尾部(包括预留的“尾空间”)。

[head,end]:缓冲区大小。

[data,tail]:报文。封装和解包本质:移动data指针在缓冲区的位置,加减对应层协议长度。

非常感谢您能耐心读完这篇文章。倘若您从中有所收获,还望多多支持呀!74c0781738354c71be3d62e05688fecc.png

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

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

相关文章

【牛客刷题】小红的数字删除

文章目录 一、题目介绍1.1 题目描述1.2 输入描述:1.3 输出描述:1.4 示例11.5 示例2二、解题思路2.1 核心观察2.2 关键问题处理三、算法实现四、算法分析4.1 算法流程图4.2 为什么这么设计算法?4.3 算法复杂度五、模拟演练数据示例1: "103252"示例2: "333&quo…

《大数据技术原理与应用》实验报告三 熟悉HBase常用操作

目 录 一、实验目的 二、实验环境 三、实验内容与完成情况 3.1 用Hadoop提供的HBase Shell命令完成以下任务 3.2 现有以下关系型数据库中的表和数据,要求将其转换为适合于HBase存储的表并插入数据: 四、问题和解决方法 五、心得体会 一、实验目的…

微服务初步入门

服务拆分原则 单一职责原则 单一职责原则原本是面向对象设计的一个基本原则,是指一个类应该专注于单一的功能,不要存在多于一个导致类变更的原因 在微服务架构中,是指一个微服务只负责一个功能或者业务领域,每个服务应该由清晰的定…

Liunx操作系统笔记5

用户管理命令: useradd命令: useradd命令的功能是创建并设置用户信息。使用useradd命令可以自动完成用户信息、基本组、家目录等的创建工作,并在创建过程中对用户初始信息进行定制。语法格式:useradd 参数 用户名常用参数: -M 不建立用…

spring-ai-alibaba 接入Tushare查询股票行情

最近spring-ai-alibaba主干分支新增了对Tushare的支持&#xff0c;一起来看看如何使用简单样例老样子&#xff0c;分三步进行&#xff1a;第一步&#xff1a;添加依赖<dependency><groupId>com.alibaba.cloud.ai</groupId><artifactId>spring-ai-aliba…

Java使用Langchai4j接入AI大模型的简单使用(一)

一、LangChain4j 简介 LangChain4j 是 Java 生态中的 LangChain 实现&#xff0c;是一个用于构建大语言模型(LLM)应用程序的框架。它提供了与各种LLM服务集成的能力&#xff0c;并简化了构建复杂AI应用的过程。 LangChain4j官方文档&#xff1a;Integrations | LangChain4j …

Linux —— A / 基础指令

建议学习路径&#xff1a;Linux系统与系统编程 ⇒ Linux网络和网络编程 ⇒ MySQL一、初识shell命令 1.1、关于 Linux 桌面很多同学的 Linux 启动进⼊图形化的桌⾯. 这个东西⼤家以后就可以忘记了。以后的工作中没有机会使用图形界面。思考: 为什么不使用图形界面? 1.2、下…

[论文阅读] 人工智能 + 软件工程 | 用大语言模型+排名机制,让代码评论自动更新更靠谱

LLMCup&#xff1a;用大语言模型排名机制&#xff0c;让代码评论自动更新更靠谱 LLMCup: Ranking-Enhanced Comment Updating with LLMsarXiv:2507.08671 LLMCup: Ranking-Enhanced Comment Updating with LLMs Hua Ge, Juan Zhai, Minxue Pan, Fusen He, Ziyue Tan Comments: …

悲观锁 乐观锁

悲观锁 乐观锁 在没有加锁的秒杀场景下 每秒打进来的请求是巨大的 高并发场景下 我们发现不仅异常率高的可怕 库存竟然还变成了负数 这产生的结果肯定是很大损失的 那为什么会出现超卖问题呢 我们假设有下面两个线程线程1查询库存&#xff0c;发现库存充足&#xff0c;创建订单…

如何使用Cisco DevNet提供的免费ACI学习实验室(Learning Labs)?(Grok3 回答)

Cisco DevNet 提供的免费 ACI&#xff08;Application Centric Infrastructure&#xff09;学习实验室&#xff08;Learning Labs&#xff09;是帮助用户学习和实践 Cisco ACI 技术&#xff08;包括 APIC 控制器&#xff09;的优秀资源&#xff0c;适合网络工程师、开发者和准备…

Combine的介绍与使用

目录一、Combine 框架介绍二、核心概念三、基础使用示例3.1、创建 Publisher & 订阅3.2、操作符链式调用3.3、Subject 使用&#xff08;手动发送值&#xff09;3.4、网络请求处理3.5、组合多个 Publisher3.6、错误处理四、核心操作符速查表 Operator五、UIKit 绑定示例六、…

【Java笔记】七大排序

目录1. 直接插入排序2. 希尔排序3. 选择排序4. 堆排序(重要)5. 冒泡排序6. 快速排序&#xff08;重要&#xff09;6.1 Hoare 法6.1.1 Hoare 法优化6.2 挖坑法&#xff08;重点&#xff09;6.3 快速排序的非递归写法7. 归并排序海量数据的排序问题8. 总结1. 直接插入排序 时间复…

H.264编解码(NAL)

在我们的日常生活中&#xff0c;比如有缓存电影或者是发送视频的需求。如果没有视频压缩&#xff0c;一部手机只能存几分钟视频&#xff0c;1TB 硬盘也装不下几部电影&#xff0c;用 4G 网络发一段 1 分钟视频&#xff0c;可能需要几十分钟&#xff08;甚至传不完&#xff09;&…

新手向:Python自动化办公批量重命名与整理文件系统

本文将详细介绍如何使用Python实现一个强大的文件批量重命名与整理工具&#xff0c;帮助开发者自动化这一繁琐过程。本教程面向Python初学者&#xff0c;通过一个完整的项目案例&#xff0c;讲解文件系统操作的核心技术。我们将构建的工具将具备以下功能&#xff1a;基于正则表…

C++ 左值右值、左值引用右值引用、integral_constant、integral_constant的元模板使用案例

C 左值右值、左值引用右值引用、integral_constant、integral_constant的元模板使用案例一、左值右值1.左值2.右值二、左值引用右值引用1.左值引用2.右值引用总结三、integral_constant四、integral_constant的元模板使用案例1.求最大整数2.内存对齐alignof关键字元模板计算内存…

c++算法一

1.双指针总结&#xff1a;1.复写0这道题&#xff0c;告诉我们要正难其反&#xff0c;我们从后向前进行重写&#xff0c;删除某些数字的时候&#xff0c;我们可以从前向后遍历&#xff0c;但是增加一些数字的时候会对后面的数据进行覆盖&#xff0c;所以要从后向前进行2.快乐数涉…

LeetCode-283. 移动零(Java)

283. 移动零 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0] 示例 2: 输入: n…

【数据库】慢SQL优化 - MYSQL

一、数据库故障的关键点 引起数据库故障的因素有操作系统层面、存储层面&#xff0c;还有断电断网的基础环境层面&#xff08;以下称为外部因素&#xff09;&#xff0c;以及应用程序操作数据库和人为操作数据库这两个层面&#xff08;以下称内部因素&#xff09;。这些故障中外…

桶排序算法深度剖析

&#x1f50d; 桶排序算法深度剖析 &#x1f3af; 核心原理图解⚙️ 完整算法流程 #mermaid-svg-LyB6SpaZ132X4Wtn {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-LyB6SpaZ132X4Wtn .error-icon{fill:#552222;}#mer…

对S32K144做的BMS安装快速开发Simulink库及BMS例程介绍

前言 本章介绍BMS硬件功能及SimuLink库为主&#xff0c;捎带介绍一些例程内容 注意&#xff1a;例程所用的协议均是自定义的 自做的SimuLink库也会不定期更新 BMS例程的内容不定期维护添加 当前的BMS没有主动均衡功能&#xff0c;这个有考虑后期加上&#xff0c;当前还处于…