惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

www.infosecurity-magazine.com
www.infosecurity-magazine.com
Vercel News
Vercel News
G
Google Developers Blog
MyScale Blog
MyScale Blog
The Register - Security
The Register - Security
I
InfoQ
Blog — PlanetScale
Blog — PlanetScale
D
DataBreaches.Net
Microsoft Security Blog
Microsoft Security Blog
V
Visual Studio Blog
V2EX - 技术
V2EX - 技术
F
Fortinet All Blogs
博客园_首页
S
Secure Thoughts
GbyAI
GbyAI
S
Security Affairs
N
News | PayPal Newsroom
Forbes - Security
Forbes - Security
Recent Announcements
Recent Announcements
H
Hackread – Cybersecurity News, Data Breaches, AI and More
Security Archives - TechRepublic
Security Archives - TechRepublic
宝玉的分享
宝玉的分享
Hugging Face - Blog
Hugging Face - Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
H
Heimdal Security Blog
A
About on SuperTechFans
P
Proofpoint News Feed
H
Help Net Security
Application and Cybersecurity Blog
Application and Cybersecurity Blog
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
Y
Y Combinator Blog
L
LINUX DO - 最新话题
Apple Machine Learning Research
Apple Machine Learning Research
L
LangChain Blog
博客园 - 叶小钗
A
Arctic Wolf
Cisco Talos Blog
Cisco Talos Blog
T
The Exploit Database - CXSecurity.com
人人都是产品经理
人人都是产品经理
T
Threat Research - Cisco Blogs
N
News and Events Feed by Topic
Security Latest
Security Latest
The Hacker News
The Hacker News
T
Tor Project blog
O
OpenAI News
博客园 - 三生石上(FineUI控件)
PCI Perspectives
PCI Perspectives
量子位
大猫的无限游戏
大猫的无限游戏
Stack Overflow Blog
Stack Overflow Blog

少数派

派早报:Google 发布 Fitbit Air 等 - 少数派 「新人报到」確認需求,再開始 - 少数派 从 SOLO 独立开发者社区,我看到了越来越多开发者开始做自己的产品 - 少数派 我怎么管理那些"不常做,但总会忘"的生活事项 - 少数派 人形机器人量产元年,数据才是具身智能的“生死线” - 少数派 BuhoLaunchpad 高度还原 Mac 启动台:开发历程与思考 - 少数派 五年陪伴依然不舍,DIY 换壳后让罗技 MX Master 3 继续服役 - 少数派 新玩意 240|少数派的编辑们最近买了啥? - 少数派 一日一技|为什么你应该关闭 iOS 的键盘声音 - 少数派 我做了个插件和 Skills,一键提取任何网站的设计规范 Design.md - 少数派 住在三四线城市的你,该开始录播客了 - 少数派 甘南秘境,大白高国 - 少数派 AI的审美:谁让把我变成川内倫子 - 少数派 返工怎能不烦恼,打工人片单总有一部是你的「嘴替」 - 少数派 为了让「上厕所」更健康,我做了一个小工具 - 少数派 AI + Skill,能够让生成的文章去除 AI 味吗? - 少数派 新玩意|韶音OpenDots ONE 耳夹式耳机 - 少数派 《美满》| 在每一个春天的晚上相爱(362) - 少数派 新玩意|优篮子 PS01 MagSnap 磁吸支架 - 少数派 自我整合手记 | 我开始早睡了:用稳定规则,为自由托底 - 少数派 用龙虾(OpenClaw)两个多月,我最深的12个体会 - 少数派 听歌时间到,12 张你可能错过的 2025 华语乐坛好专辑 - 少数派 承诺能追吗 - 少数派 macOS 26启动台没了? 我做了个不一样的App启动器 - Keboard - 少数派 《四海为家的人》| INTJ对话INTJ(361) - 少数派 你发过的那些黑历史,是时候一次清干净了 - 少数派 新玩意:安安静静玩,越玩越专注:计客密码机 - 少数派 iPad 用户首次体验 Android 平板:vivo Pad6 Pro - 少数派 数据逻辑强 - 少数派 极北行+ | 一路向北,探访日本至北之地 | 001 - 少数派 万字剖析:千问App深度体验报告(2026) - 少数派 在2026年,如何真正防止别人抄袭你的作品 - 少数派 怎么用 50 块搭个 AI 语音助手?我踩了 3 天坑 - 少数派 YeeroAI:让 AI 对话真正成为知识管理的一部分 - 少数派 爬泰山 - 少数派 「旅图显影」 App 更新:这次,我们补上了一点「手感」 - 少数派 假期出门太折磨?我的 23 条经验帮你规划惬意旅行 - 少数派 工作流会变吗 - 少数派 Claude Opus 4.6 怎么用最省钱?我测了 5 种方案 - 少数派 GPT Image 2 让图文并茂不再稀罕 - 少数派 用户侧出发——什么是AI,我要不要学习? - 少数派 找片、转存、整理、播放一条龙!让你的付费网盘值回票价 - 少数派 欢迎试用!日课一问2.0插件 - 少数派 自己做的MDeditor,原本想购买 Typora 试了两次支付不成功,干脆自己做一个 - 少数派 vibe coding了一个 3MB 的小工具,让 ~/Downloads 彻底告别混乱 - 少数派 因为受不了 Mac 的风扇策略,我做了一个风扇控制工具 - 少数派 别只怪模型 - 少数派 Warp 终端的 AI 功能怎么用?我测了一周的体验 - 少数派 AI 写代码老是出 bug?这 5 个配置我后悔没早知道 - 少数派 「新玩意」苹果出相机可能就这样:Sigma BF + 45mm F2.8 DG Contemporary - 少数派 一个面向2030年的AI操作系统是什么样子的:浅谈cola这款有灵魂的Agent - 少数派 别只看写代码 - 少数派 每天解决10个问题,还是一口气攻坚解决400个? - 少数派 AI 交易机器人怎么搭?我用 Claude 跑了一周实盘 - 少数派 Maptoposter Online:把你爱的城市画成艺术海报 - 少数派 Function Calling 怎么用?我测了 3 个模型发现差距真大 - 少数派 Legend Talk:我做了个 AI 圆桌,让 160 位思想家围着你的问题转 - 少数派 如何找到自己的蓝方?在小县城寻找压力测试 - 少数派 语音输入与软件接口|2026年聊AI时,我们都聊些什么(上) - 少数派 混动已经卖爆,纯电又来补刀——钛7闪充版简直“不讲武德” - 少数派 本月玩什么|朋友收藏、识质存在、沙罗周期 - 少数派 为什么要每天坚持输出? - 少数派 Claude API 挂了好几个小时,你的项目有备用方案吗? - 少数派 Function Calling 没你想的复杂——我用它做了个有点用的工具 - 少数派 登录系统立即播放视频或者图片音乐的软件 - 少数派 我为什么创建 FlipHTML5 下载工具 - 少数派 残局没电?多品牌外设电量统一管理软件EasyBluetooth已支持RTSS游戏内显示以及AIDA64 - 少数派 前往通义路的路 - 少数派 太好看了,媲美Sun的个人导航页,NAS部署星云门户 - 少数派 乌黑嘴唇“一键检测”上线了 - 少数派 派早报:Claude AI 接入多个创意软件生态、FILCO 生产方接手品牌等 - 少数派 【更新】BearCLI、Claude 连接器与 MCP 服务器 - 少数派 记了上千条流水,还是看不懂财务?我做了一个让 AI 读懂账本的工作台 - 少数派 MINI R56 升级原厂 Sport 模式 - 少数派 新玩意 | 一棵柠檬树(仿真版) - 少数派 Momenta的“物理AI”野望,需迈过“含摩量”这道关 - 少数派 网页直接投屏控制手机!NAS一键部署PandaScrcpy,流畅丝滑可远程。 - 少数派 众测|邀你一同探索随身 AI 硬件入口 YoooClaw C·ONE - 少数派 2050大会:分享时间是真诚 参会记 - 少数派 iPad 赋能电影创作:国内首部宣纸手绘长片《燃比娃》的幕后故事 - 少数派 AI的审美:我用 8 个大模型给 100 张旅行照片打分 - 少数派 普通人如何破圈?去参加一个本地协会 - 少数派 把极空间的图标全换了,主题DIY全攻略打造你的专属NAS桌面 - 少数派 电子便签墙,帮你实现便签自由 - 少数派 我如何用三个 CLI 工具取代文档创建需求 - 少数派 原来真的有人可以玩一辈子 - 少数派 社区速递 139 | 派友热议三月买了啥、复古单反尼康 Df 体验 - 少数派 06 作品的赏析与评价 - 少数派 TDS REVIEW|索尼 WF-1000XM6 降噪真无线耳机体验 - 少数派 35.98万起售的第二代腾势D9,我看重的不是堆料,而是不凑合 - 少数派 鼠须管 Squirrel 皮肤配置指北 - 少数派 从watch ultra2换到redmi watch6 - 少数派 派早报:阿里巴巴发布视频生成模型 HappyHorse 1.0 等 - 少数派 别迷信1M - 少数派 家人们天塌了!网盘“大封杀”,多个渠道多条路,NAS部署PanHub - 少数派 AI与人勾心斗角!NAS一键部署AI狼人杀,假日休闲必备。 - 少数派 电商必备!Comfyui工作流批量生图插件,一次生成12张!支持Nano banana pro模型 - 少数派 Comfyui工作流配置Gpt-image-2模型教程,0.03/张 - 少数派 OpenClaw第三方APi怎么配置?可使用Gpt-image-2模型 - 少数派 会员社区话题精选 Ep. 103 - 少数派
小白也能看懂的网络基础 07 | TCP和UDP是如何工作的? - 少数派
2021-03-12 · via 少数派

引言

欢迎来到网络世界,《小白也能看懂的网络基础》系列文章会从零开始帮助你构建网络的基础知识。如果你完全没有接触过网络相关的内容,那我们是一样的,在学习过程中我们肯定遇到了相同的问题!写下这些文章一方面要记录自己的学习历程,另一方面也希望帮到同样想要学习网络基础的小伙伴。

文章的部分内容与素材是我从 YouTube 频道 Network Direction 发布的系列视频学习和搜集过来的,翻译不易,部分内容可能无法做到尽善尽美,甚至可能会有部分瑕疵,我会尽力让文章内容通俗易懂,覆盖全面。若各位小伙伴发现任何问题,希望能够留言或私信告诉我,在下不胜感激!当然,我也会在第一时间进行更正。

在往后的每一篇文章中,我都会把看到文章的小伙伴当成是完全没有网络经验的小白,我的目标是和零基础小白一起建立坚实的网络基础,网络大神请略过此系列文章。

让我们开始网络之旅吧!


回顾

我们已经学习并掌握了OSI和TCP/IP模型的基本原理,接下来,我们将重点介绍传输层中的两个协议,那就是「TCP」和「UDP」,我们将看一下,一个应用程序如何获取另一个应用程序的信息,同时,了解一下它们工作方式上有什么不同。

网络上的设备通过IP地址来实现彼此之间的信息传递,这种情况发生在第三层,也就是网络层,可能包括跨多个网络路由的数据包。

TCP & UDP

在第四层有这与第三层截然不同的操作行为,「传输层」是不在乎数据是在什么网络之间传递的,也不在乎发送与接收信息的设备是什么类型,它更关心的是应用程序之间如何实现数据交互

负责此操作的两个角色就是「TCP协议」和「UDP协议」。

1.共同点

1.1 都具有Headers头

共同点

首先,我们来看一下它们的共同点,它们都有「Headers标头」,而标头中都包含了「端口号」,通过图片,我们可以清晰的看到TCP的作用确实比UDP要多得多,由此可见,TCP支持更多功能,而UDP非常轻量。

1.2 都具有源目端口

除此之外,我们还能看到,它们都拥有「源目端口」,在之前章节的HTTP请求案例我们已经了解到,源目端口是客户端应用与服务器端应用交互的重要桥梁,我们可以把端口理解为一个应用程序的地址,每个应用都具有端口,就像每张网卡都具有MAC地址一样,最终目的都是为了准确找到对方。

源目端口

当我们打开一个应用程序,这就启动了一个会话,而这个会话一定会有一个源端口,其端口值通常都在0~65535之间,这里需要注意,一个端口只能分配给一个应用,它是具有唯一性的,若同时把一个端口分配给两个应用,则会导致某一个应用无法正常运行。

1.3 知名端口

另外,为了给某些系统服务更好的支持,0~1023范围的端口,通常都会预留给系统服务,我们通常称这类端口为「知名端口」,例如:我们使用HTTP请求时,给我们提供网络浏览的端口,通常就是80端口。

1.4 非知名端口

1024~65535这个范围的端口则成为「非知名端口」,我们可以对其进行自由支配。

2.端口特点

2.1 端口调整

如果使用知名端口,我们可以很容易的知道目前正在使用的是什么程序,并且知道它占用了哪个端口。当然,在特定情况下,我们也可以对知名端口进行调整,例如,将HTTP请求端口修改为8080或8888也是我们非常常用的修改,但这样一来,知名端口就变成非知名了,同时,若我们不知道该应用的端口,也就不知道对方提供的是什么服务了。

2.2 多路复用

使用不同的端口,可以给我们提供一个非常使用的功能,那就是「多路复用」,多路传输,即一个服务器主机可以让多个客户端应用程序同时访问,而这些客户端应用程序使用的都是同一个网卡、同一个IP地址,而实现这一切的就是因为不同的应用使用了不同的端口。

参考图示,我们可以看到,客户端这边有一个邮箱应用、有一个浏览器应用,他们的IP都是10.0.0.1,但是端口不同,邮箱是16423,浏览器是34761,因此它们两个可以同时向服务器发起请求而不会起冲突,这都是端口的功劳。

3. 套接字(Socket)

我们应该都听过这个名词,「套接字(Socket)」,它的确切定义有所不同,通常情况下,我们都会理解它是由「本地IP地址」、「本地端口号」以及「协议」三部分组成,这里的协议指的就是TCP或UDP。

有了套接字,我们就可以轻松的识别出网络中的请求属于哪个应用程序,而不会出现「串错门」的情况,每一次网络请求,我们都会检查套接字中的本地与远程的信息,从而使得我们可以准确的进行后续操作。套接字属于TCP/IP模型中的第三层和第四层。

套接字与五元组

3.1 五元组

现在,我们拥有了「本地IP地址」、「本地应用端口」、「远程IP地址」、「远程应用端口」、「协议」这五条信息,通常我们会把它们看做一个整体,称之为「五元组」,五元组中的信息都是独一无二的。

4.案例演示

我们这里使用Windows来做一下演示(Linux、MacOS操作系统原理相同),打开Windows的任务管理器,查看详细信息列表,以谷歌浏览器为例,我们会发现有好多谷歌浏览器的进程,且他们后面的「PID」也不尽相同,就是这些进程,组成了一个应用程序。

有些应用程序只有一个进程,而有些应用程序则会有多个进程,其中一些进程是用来访问网络的,这意味着它们将被分配TCP或UDP端口。

我们也可以使用「netstat」命令,并配合「-ano」选项,在DOS系统中显示所有连接信息,可以同时看到进程的详细信息,例如,通过查看左侧的协议,我们就可以知道,每一项进程采用了TCP还是UDP,他们的本地IP地址、本地端口号、远程IP地址、远程端口号、链接状态以及最右侧的PID进程号。

5.小测试

  1. 问题一
    问:查看下面两张图,哪个是TCP标头,哪个是UDP标头?
    答:标头比较多的是TCP,较少的是UDP
  2. 问题二
    问:套接字(Socket)是用来做什么的?
    答:① 套接字用于跟踪网络对话中的本地信息。
            ② 尽管套接字的确切定义有所不同,但大多数人都同意它包含协议「TCP」或「UDP」,也就是本地IP地址(第三层)和本地端口(第四层)。
            ③ 套接字对于使用它的应用程序或进程是唯一的,对于服务器端来说,可能比较头疼,服务器通常一次处理许多链接,而套接字只用于描述本地的详细信息。
            ④ 相反,我们可以使用「五元组」来跟踪对话的两端,因为它包含了本地IP,本地端口,远程IP,远程端口。

二、TCP与UDP的区别

到这里,大家可以发现,我们的内容都是围绕TCP和UDP展开的,虽然它们有很多通用的地方,但通过标头信息我们可以确定,TCP和UDP是两个完全不同的概念。

1.轻量与非轻量

UDP是轻量级的,通常都会被分配一些较轻量的任务;而TCP因其完整的内容体系,通常都会涉及许多额外的功能。

2.连接与无连接

2.1 TCP面向连接

例如TCP是面向连接的,而UDP是面向无连接的。面向连接的意思就是,TCP将在一对主机上建立并跟踪双方应用程序之间的会话连接,在准备好数据之后进行发送,之后关闭连接;但TCP的任务还没结束,相反它会启动更多的功能,例如:错误恢复、流量控制等。

2.2 UDP无连接

然而UDP则不会尝试建立连接,它只会开始准备自己的数据,而不去担心那些细节,UDP对于错误的处理方式也和TCP完全不同!对于UDP来说,数据包或数据段丢失与否,它并不关心,相反,会继续传输下一个数据。

TCP则不同了,它非常在意每一次数据传输的完整性,准确性,一旦发生丢失,它便会将丢失的部分重新传递!

3.窗口化

也正因为如此,TCP被认为是可靠的伙伴,UDP则通常被认为是不可靠的,因为TCP的这一特性,催生出了「窗口化」这个TCP的功能,窗口化的概念就是,”一台设备向另一台设备传递了某段消息,接收方必须对这段消息做出相应,若发送方没有收到响应,则会尝试重新发送该段内容“。

3.1 窗口大小

因此,对于一次可以发送多少数据,接收方必须确认这一点,该值称为「窗口大小」,如果没有丢失数据,则窗口大小可以「动态增长」;如果有数据丢失,则窗口大小可以「动态缩小」

3.2 数据切片与排序

由于较大的数据信息会被切片,对于数据段的顺序问题,TCP会使用标头中的序列号来追踪数据段的顺序信息,这对于某些应用程序可能很关键,例如:QQ中的文件分享,若中断了,下次连接需要接着上次的进行传递,也称为「断点续传」。

而对于一些应用程序,这并不重要,这也是为什么我们要使用UDP的原因,那UDP到底有什么作用呢?它看起来功能很少,而且似乎缺乏某些关键的功能,忽视顺序,忽视错误,确定能作为传输协议?

4.UDP终极奥义

话不多说,直接上案例,大家可以想象一下我们在使用语音或视频通话这类实时交互的应用,例如:微信语音,微信视频,QQ语音,QQ视频等等,若由于网络原因,导致语音、或视频卡顿,必定会造成音频流或视频流数据的丢失。

对于TCP来说,由于其严谨的态度,每次丢失的数据都要重新整理发送,这样一来,我们可能永远在和一个有延时的人进行语音或视频通话,这反而影响我们的使用体验。

相反,如果我们抱有这样一种态度,这些包丢了就丢了吧,一会网络好了再重新说一遍就好了……大家心里应该清楚了,对于语音与视频这种通讯方式通常都会使用UDP协议,它可以有效的避免一些问题的发生。

现在,我们知道了,TCP和UDP各有所长,TCP更完整,更严谨,而UDP更轻便,对于实时通话支持友好!因此,在合适的位置使用合适的协议显得尤为重要!

4.1 小测试

  1. 问题一
    问:TCP和UDP的主要区别是什么?
    答:① UDP标头比TCP标头少很多,尽管TCP功能更多,但是UDP更为轻量。
            ② TCP具有错误恢复功能,而UDP对错误一点都不关心。
            ③ TCP具有流控制,而UDP没有流控制。
            ④ TCP是面向连接的协议,而UDP是无法连接的
  2. 问题二
    问:那个协议会执行错误检测?
    答:这是一个技巧问题!
            UDP和TCP都具有有限的错误检测功能,因为它们可以使用其标头中的校验和字段来进行检测!
            但是,绝大多数错误检测都发生在第二层。例如:以太网将检测到错误并丢弃帧。当出现错误并且数据丢失的时候,TCP能够恢复,它会注意到有数据丢失,并请求重新发送,而UDP则没有此功能。
  3. 问题三
    问:如果TCP这么好,为什么还要使用UDP?
    答:UDP是轻量级的,因为它具有较小的标头,并且跳过诸如错误恢复和流控制之类的人物。因此,如果应用程序不需要这些功能(例如语音和视频流),或者这些功能在内置的应用程序中(例如DNS),则UDP要快的多。

原作者:

作者的其他文章:

  1. 小白也能看懂的网络基础 01 | 什么是网络?
  2. 小白也能看懂的网络基础 02 | 连接设备
  3. 小白也能看懂的网络基础 03 | OSI 模型是如何工作的?
  4. 小白也能看懂的网络基础 04 | IP 地址是如何工作的?
  5. 小白也能看懂的网络基础 05 | IP地址深度学习
  6. 小白也能看懂的网络安全 06 | TCP/IP 模型是如何工作的?
  7. 小白也能看懂的网络基础 07 | TCP和UDP是如何工作的?