【在Linux世界中追寻伟大的One Piece】传输层协议UDP

1 -> 传输层

传输层是计算机网络OSI模型中的第四层,负责在网络中的两个节点之间提供端到端的数据传输服务。其主要任务包括数据分段与重组、端口标识、连接控制(如面向连接的TCP和无连接的UDP)、流量控制以及差错检测与处理。这些功能确保数据传输的可靠性、有序性和高效性。

简单来说,传输层确保数据从发送端顺利传输到接收端。

2 -> 端口号

端口号(Port)用于标识一台主机上不同应用程序之间的通信。

【在Linux世界中追寻伟大的One Piece】传输层协议UDP在TCP/IP协议中,通过”源IP”、”源端口号”、”目的IP”、”目的端口号”和”协议号”这五元组来唯一标识一个通信连接(可以通过netstat -n命令查看)。

【在Linux世界中追寻伟大的One Piece】传输层协议UDP2.1 -> 端口号范围划分

0 – 1023:被称为知名端口号,用于HTTP、FTP、SSH等常用应用层协议,这些端口号是固定的。1024 – 65535:由操作系统动态分配,客户端程序的端口号通常从这个范围内分配。

2.2 -> 知名端口号

常用服务器使用固定端口号以便于识别和使用:

ssh服务器使用22端口,ftp服务器使用21端口,telnet服务器使用23端口,http服务器使用80端口,https服务器使用443端口。可以通过特定命令查看这些知名端口号。

在编写程序时,应当避免使用这些知名端口号。

3 -> UDP协议

UDP(用户数据报协议)是一种无连接的传输层协议,提供简单且面向报文的数据传输服务。

UDP不保证数据包的可靠交付、顺序或完整性,不进行拥塞控制,也不需要在传输数据前建立连接。

UDP的头部开销较小,仅8字节,包括源端口、目的端口、长度和校验和字段。

由于其简单性,UDP适用于对实时性要求高的应用,如在线游戏、语音视频通信和某些网络广播。

3.1 -> UDP协议端格式

【在Linux世界中追寻伟大的One Piece】传输层协议UDPUDP长度字段为16位,表示整个数据报(UDP首部+UDP数据)的最大长度。如果校验出错,数据报将被直接丢弃。

讯飞听见会议 讯飞听见会议

科大讯飞推出的AI智能会议系统

讯飞听见会议 19 查看详情 讯飞听见会议

3.2 -> UDP的特点

UDP传输类似于寄信:

无连接:只需知道对端的IP和端口号即可直接传输,无需建立连接。不可靠:没有确认和重传机制;如果网络故障导致数据包无法送达,UDP不会向应用层返回错误信息。面向数据报:不能灵活控制读写数据的次数和数量。简单高效:UDP头部开销小,仅8字节,适合快速传输数据,尤其是对实时性要求高的应用。支持广播和多播:UDP可实现单播、广播和多播通信,适合发送数据到多个目的地。无流量控制:UDP不提供流量控制功能,网络拥塞时可能导致数据包丢失或传输延迟增加。适用场景:UDP适用于实时音视频通话、在线游戏、DNS查询等对实时性要求高的应用。

3.2.1 -> 面向数据报

应用层交给UDP的数据报文,UDP会原样发送,不拆分也不合并。

例如,使用UDP传输100个字节的数据:

如果发送端通过一次sendto发送100个字节,那么接收端也必须通过一次recvfrom接收这100个字节,而不能通过多次recvfrom接收,每次接收10个字节。

3.3 -> UDP的缓冲区

UDP没有真正的发送缓冲区。调用sendto后,数据直接交给内核,由内核传递给网络层协议进行后续传输。UDP有接收缓冲区,但不能保证接收到的UDP报文的顺序与发送顺序一致;如果缓冲区已满,新的UDP数据将被丢弃。UDP的socket支持读写操作,这被称为全双工。

3.4 -> UDP使用注意事项

UDP协议首部中有一个16位的最大长度字段,这意味着一个UDP数据报的最大长度为64K(包括UDP首部)。

然而,在当今的互联网环境下,64K是一个非常小的数字。

如果需要传输的数据超过64K,必须在应用层手动分包多次发送,并在接收端手动拼装。

3.5 -> 基于UDP的应用层协议

NFS(网络文件系统):用于网络文件共享。TFTP(简单文件传输协议):用于简单文件传输。DHCP:动态主机配置协议,用于自动分配IP地址。BOOTP:启动协议,用于无盘设备启动。DNS(域名解析系统):用于将域名解析为IP地址。SNMP(简单网络管理协议):用于网络设备和应用程序的管理,可以使用UDP作为传输层协议。RIP(路由信息协议):一种基于距离矢量算法的路由协议,使用UDP进行信息交换。QUIC(快速UDP互联网连接):由谷歌开发的基于UDP的传输层协议,旨在减少连接延迟,提供安全和可靠的连接。UDT(基于UDP的数据传输协议):一种面向连接的双向应用层协议,建立在UDP之上,支持高速数据传输和可靠性控制。

当然,也包括你自己编写的基于UDP的自定义应用层协议。

感谢各位大佬的支持!!!

互三啦!!!

以上就是【在Linux世界中追寻伟大的One Piece】传输层协议UDP的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/455610.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 01:17:47
下一篇 2025年11月8日 01:19:05

相关推荐

  • 谷歌搜索的鼠标悬停阴影效果是如何实现的?

    谷歌搜索悬停阴影效果解析 在谷歌搜索页面中,当鼠标悬停在搜索框或按钮上时,会出现一个微妙的边缘阴影。想要了解这一效果的实现原理,许多开发者可能率先想到使用 css。 css 探索 遗憾的是,在 css 代码中无法找到与阴影效果直接相关的属性或值。继续探索其他实现方法。 浏览器开发者工具助力 使用浏览…

    2025年12月24日
    000
  • 如何用 CSS 实现谷歌搜索框鼠标悬停时的边缘阴影效果?

    谷歌搜索框鼠标悬停时边缘阴影效果实现 对于谷歌搜索框在鼠标悬停时的边缘阴影效果,你可能找不到直接的 css 代码,但这种效果可以通过 box-shadow 属性实现。 box-shadow 可以创建箱子周围的阴影效果,它的语法如下: box-shadow: h-offset v-offset blu…

    2025年12月24日
    200
  • 如何实现谷歌搜索框鼠标悬停时的边缘阴影效果?

    如何实现谷歌搜索框鼠标悬停时的边缘阴影效果? 在谷歌搜索中,当鼠标悬停在搜索框和按钮上时,会产生一种精致的边缘阴影效果。实现这一效果需要使用 css 的 box-shadow 属性。 box-shadow 属性 box-shadow 属性允许在元素周围创建阴影效果。其语法为: box-shadow:…

    2025年12月24日
    200
  • 鼠标悬停时,谷歌搜索元素的阴影效果是如何实现的?

    鼠标悬停时突出显示谷歌搜索元素的阴影效果是如何实现的 该效果是通过 css 的 box-shadow 属性实现的,该属性用于在元素周围创建阴影效果。 当鼠标悬停在元素上时,应用 :hover 伪类,并添加 box-shadow 属性,为元素指定阴影效果。 下面是一个示例 css 代码,它给谷歌搜索框…

    2025年12月24日
    100
  • CSS 砌体 Catness

    css 就像技术中的其他东西一样 – 它总是在变化和发展。该领域正在进行的开发是 css 网格布局模块级别 3,也称为 css masonry 布局。 theo 制作了一段视频,介绍了它的开发方式以及苹果和谷歌就如何实施它进行的辩论。 所有这些让我很高兴尝试 css 砌体! webkit…

    好文分享 2025年12月24日
    000
  • Bear 博客上的浅色/深色模式分步指南

    我最近使用偏好颜色方案媒体功能与 light-dark() 颜色函数相结合,在我的 bear 博客上实现了亮/暗模式切换。 我是这样做的。 第 1 步:设置 css css 在过去几年中获得了一些很酷的新功能,包括 light-dark() 颜色函数。此功能可让您为任何元素指定两种颜色 &#8211…

    2025年12月24日
    100
  • 谷歌浏览器重命名文件后缩进消失,火狐浏览器却不会,这是为什么?

    谷歌浏览器重命名文件后缩进消失,而火狐浏览器不会 在谷歌浏览器中使用 WEB IDE 时遇到一个奇怪的问题。当重命名目录树中的文件后,目录树左侧的缩进消失了。但是,在开发者工具中发现导致缩进消失的其实是设置了 margin-right: -17px,而不是正常的 margin-left: -17px…

    2025年12月24日
    000
  • 为什么重命名文件后,谷歌浏览器和火狐浏览器的目录树缩进表现不同?

    为什么在重命名文件后,谷歌浏览器和火狐浏览器的目录树表现不同? 一位开发者遇到了一个令人迷惑的问题:在谷歌浏览器中的 WEB IDE 中重命名文件时,目录树中的缩进会消失。经过检查,开发者发现目录树元素有一个 margin-right:-17px 样式,这与预期中 margin-left:-17px…

    2025年12月24日
    300
  • 谷歌浏览器和火狐浏览器在重命名文件时,为何表现出不同的缩进差异?

    浏览器在重命名文件时表现差异的原因 当你使用谷歌浏览器中的 WEB IDE 重命名文件时,你遇到的问题是:整个目录树向左移动,缩进消失。同时,你发现该元素设置了 margin-right: -17px,但它应该设置为 margin-left: -17px。 这个问题的原因是因为谷歌浏览器在处理 CS…

    2025年12月24日
    200
  • 谷歌浏览器目录树缩进消失:是 Bug 还是配置问题?

    浏览器中的目录树缩进差异 问题: 在谷歌浏览器使用 WEB IDE 时,重命名文件会消除目录树的缩进,但火狐浏览器没有这个问题。这是谷歌的 Bug 吗? 答案: 不是谷歌的 Bug。 解释: 在 Google 浏览器中,浏览器错误地将 margin-right:-17px 应用于目录树元素,而不是 …

    2025年12月24日
    000
  • 如何在 Web 开发中检测浏览器中的操作系统暗模式?

    检测浏览器中的操作系统暗模式 在 web 开发中,用户界面适应操作系统(os)的暗模式设置变得越来越重要。本文将重点介绍检测浏览器中 os 暗模式的方法,从而使网站能够针对不同模式调整其设计。 w3c media queries level 5 最新的 web 标准引入了 prefers-color…

    2025年12月24日
    000
  • 如何使用 CSS 检测操作系统是否处于暗模式?

    如何在浏览器中检测操作系统是否处于暗模式? 新发布的 os x 暗模式提供了在 mac 电脑上使用更具沉浸感的用户界面,但我们很多人都想知道如何在浏览器中检测这种设置。 新标准 检测操作系统暗模式的解决方案出现在 w3c media queries level 5 中的最新标准中: 立即学习“前端免…

    2025年12月24日
    000
  • 如何检测浏览器环境中的操作系统暗模式?

    浏览器环境中的操作系统暗模式检测 在如今科技的海洋中,越来越多的设备和软件支持暗模式,以减少对眼睛的刺激并营造更舒适的视觉体验。然而,在浏览器环境中检测操作系统是否处于暗模式却是一个令人好奇的问题。 检测暗模式的标准 要检测操作系统在浏览器中是否处于暗模式,web 开发人员可以使用 w3c 的媒体查…

    2025年12月24日
    200
  • 浏览器中如何检测操作系统的暗模式设置?

    浏览器中的操作系统暗模式检测 近年来,随着用户对夜间浏览体验的偏好不断提高,操作系统已开始引入暗模式功能。作为一名 web 开发人员,您可能想知道如何检测浏览器中操作系统的暗模式状态,以相应地调整您网站的设计。 新 media queries 水平 w3c 的 media queries level…

    2025年12月24日
    000
  • 如何在 VS Code 中解决折叠代码复制问题?

    解决 VS Code 折叠代码复制问题 在 VS Code 中使用折叠功能可以帮助组织长代码,但使用复制功能时,可能会遇到只复制可见部分的问题。以下是如何解决此问题: 当代码被折叠时,可以使用以下简单操作复制整个折叠代码: 按下 Ctrl + C (Windows/Linux) 或 Cmd + C …

    2025年12月24日
    000
  • 我在学习编程的第一周学到的工具

    作为一个刚刚完成中学教育的女孩和一个精通技术并热衷于解决问题的人,几周前我开始了我的编程之旅。我的名字是OKESANJO FATHIA OPEYEMI。我很高兴能分享我在编码世界中的经验和发现。拥有计算机科学背景的我一直对编程提供的无限可能性着迷。在这篇文章中,我将反思我在学习编程的第一周中获得的关…

    2025年12月24日
    000
  • 姜戈顺风

    本教程演示如何在新项目中从头开始配置 django 和 tailwindcss。 django 设置 创建一个名为 .venv 的新虚拟环境。 # windows$ python -m venv .venv$ .venvscriptsactivate.ps1(.venv) $# macos/linu…

    2025年12月24日
    000
  • 如何查看编写的html_查看自己编写的HTML文件效果【效果】

    要查看HTML文件的浏览器渲染效果,需确保文件以.html为扩展名保存、用浏览器直接打开、利用开发者工具调试、必要时启用本地HTTP服务器、或使用编辑器实时预览插件。 如果您编写了HTML代码,但无法直观看到其在浏览器中的实际渲染效果,则可能是由于文件未正确保存、未使用浏览器打开或文件扩展名设置错误…

    2025年12月23日
    400
  • html5怎么设置月份_HTML5用input type=”month”让用户选择年月月份【设置】

    HTML5的input type=”month”提供原生年月选择器,格式为“YYYY-MM”,支持value默认值、min/max范围限制、name表单提交,并需JavaScript降级兼容旧浏览器。 如果您希望在网页中提供一个简洁的年月选择控件,HTML5 的 input …

    2025年12月23日
    200
  • html5怎么设置黑体_html5用CSS font-family设黑体或font-weight加粗【设置】

    在HTML5中实现黑体及加粗需用CSS的font-family和font-weight:一、font-family按优先级列“SimHei”,“Microsoft YaHei”,“Heiti SC”,sans-serif;二、font-weight用700或bold;三、组合声明并注意继承;四、可用…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信