news 2026/4/1 10:47:35

网络传输原理(TCP/IP)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
网络传输原理(TCP/IP)

将内存中某个地址的数据通过网口发送出去,本质是数据从用户态内存→内核态内存→网卡硬件→物理链路的传递过程,同时伴随TCP/IP 协议栈的逐层封装操作系统 / 硬件的资源调度。以下按 ** 软件层(应用 + 内核)→硬件层(网卡 + 物理层)** 的顺序,拆解完整流程(以 Linux 系统下的 TCP/UDP 发送为例,这是最常见的场景)。

一、应用程序层:发起数据发送请求

  1. 数据准备:应用程序将待发送的数据存放在用户态的内存地址中(比如char buf[] = "hello"对应的内存地址)。
  2. 调用套接字 API:应用程序通过标准的网络套接字(Socket)API(如send()/sendto()/write()),向内核协议栈发起数据发送请求,传入的参数包括:
    • 套接字描述符(标识与目标主机的网络连接);
    • 数据的内存地址和长度;
    • 目标地址(IP + 端口,UDP 需显式指定,TCP 已通过三次握手建立连接)。
  3. 用户态→内核态切换:由于send()系统调用,CPU 会从用户态切换到内核态,执行内核协议栈的对应逻辑(这一步会有少量开销,是用户态与内核态的边界)。

二、内核协议栈层:数据封装与调度(核心步骤)

内核协议栈会对数据进行逐层封装,并完成传输层、网络层、链路层的逻辑处理,具体分为 6 个步骤:

1. 套接字缓冲区(Socket Buffer)处理
  • 内核不会直接读取用户态内存的数据,而是先将数据从用户态内存拷贝到内核态的套接字缓冲区(sk_buff)(这是一次关键的内存拷贝,高性能场景会用sendfile()/mmap()跳过此拷贝);
  • 若数据长度超过缓冲区阈值,会被拆分到多个缓冲区中。
2. 传输层封装(TCP/UDP)
  • UDP 协议(无连接):在数据前添加UDP 头,包含源端口、目的端口、数据长度、UDP 校验和(可由硬件卸载)。
  • TCP 协议(面向连接):
    1. 先检查连接状态(是否已完成三次握手),若未建立则返回错误;
    2. 为数据添加TCP 头,包含源端口、目的端口、序列号、确认号、窗口大小、校验和等;
    3. 执行 TCP 拥塞控制、流量控制(如滑动窗口),决定数据是否可以立即发送;
    4. 将封装后的 TCP 报文放入发送队列。
3. 网络层封装(IP)
  • 协议栈根据目标 IP 地址,通过路由表查找下一跳地址(确定出网卡);
  • 为传输层报文添加IP 头,包含源 IP、目的 IP、协议类型(TCP=6,UDP=17)、IP 长度、TTL、IP 校验和(可由硬件卸载);
  • 若封装后的 IP 报文长度超过网卡的 MTU(以太网默认 1500 字节),则执行IP 分片,将大报文拆分为多个 MTU 大小的 IP 包。
4. 链路层封装(以太网帧)
  • 根据下一跳 IP 地址,通过ARP 协议解析出对应的MAC 地址(若 ARP 缓存中无记录,会先发送 ARP 请求获取);
  • 为 IP 报文添加以太网帧头,包含目的 MAC、源 MAC、帧类型(0x0800=IPv4,0x0806=ARP);
  • 在帧尾部添加CRC 校验码(用于链路层错误检测,可由硬件生成)。
5. 内核→网卡驱动的数据传递
  • 内核将封装好的以太网帧,通过DMA(直接内存访问)机制,从内核缓冲区传递到网卡的硬件缓冲区(NIC Buffer);
    • 注:DMA 无需 CPU 参与,由网卡控制器直接访问内存,大幅提升效率。
  • 网卡驱动程序向网卡硬件发送发送指令,触发网卡开始处理数据。
6. 内核态→用户态切换
  • 数据传递完成后,内核返回发送结果(如发送的字节数),CPU 从内核态切换回用户态,应用程序继续执行后续逻辑。

三、网卡硬件层:物理层信号发送

网卡(包含 MAC 控制器和 PHY 芯片)负责将数字帧数据转换成物理层信号并发送,分为 3 个步骤:

  1. MAC 控制器处理:网卡硬件读取自身缓冲区中的以太网帧,验证 CRC 校验(若硬件生成则跳过),并按照以太网标准进行帧同步处理(添加前导码和帧起始符)。
  2. PHY 芯片处理:MAC 控制器将帧数据传递给 PHY 芯片(物理层),PHY 芯片将数字比特流转换成物理层信号
    • 有线以太网(RJ45):转换成差分电信号(如 1000BASE-T 的 4 对双绞线信号);
    • 光纤以太网:转换成光信号。
  3. 物理链路发送:PHY 芯片通过网线 / 光纤将信号发送到网络中(交换机、路由器等),最终传递到目标主机。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 23:48:34

大模型应用开发:从RAG到Agent的智能问答系统优化之路,解决场景区分不清的难题

文章讲述了智能问答系统从纯RAG技术到结合Agent技术的优化过程。针对三个子场景中结构化和非结构化数据混合查询的问题,作者最初按场景建立三个知识库,但遇到召回率低、场景判断不准的困境。后改为从数据类型维度建立两个知识库(结构化和非结…

作者头像 李华
网站建设 2026/3/28 21:29:02

一文彻底搞懂AI Agent:从概念到两种核心设计模式(图文详解)

本文详细介绍了AI Agent的概念,解释了它如何通过工具实现对外部环境的感知和改变,重点阐述了ReAct模式和Plan-And-Execute模式两种核心设计原理。ReAct模式通过思考-行动-观察的循环处理任务,而Plan-And-Execute模式则先制定计划再执行&#…

作者头像 李华
网站建设 2026/4/1 2:43:14

【扣子编程】| 2000字实操指南(Coze最新上线)

目录 01 扣子编程是什么? 02 扣子编程能做什么? 03 实操指南 ▐ 入口 ▐ 界面展示 ▐ 核心功能(亮点) 网页应用 智能体 工作流 04 问答环节 05 结语 扣子最新上线了新功能 扣子编程,主打 “让不会编程的人也…

作者头像 李华
网站建设 2026/3/28 20:42:54

RPA实时监控希音网站流量,异常告警效率提升20倍![特殊字符]

RPA实时监控希音网站流量,异常告警效率提升20倍!📊 "凌晨3点,运维团队还在手动记录网站流量数据,突然的流量暴跌让整个团队措手不及...这样的惊魂夜该终结了!" 一、痛点直击:流量监控…

作者头像 李华
网站建设 2026/3/28 10:48:58

儿童生长曲线分析技术深度解析:原理、实现与预警机制

本文从技术视角深入探讨儿童身高体重管理的核心挑战,详细解析生长曲线分析的原理、标准化数据来源及百分位/Z-score计算方法。并以长高乐APP为例通过Python代码示例展示数据模型设计、API接口实现与可视化技术,并系统阐述基于生长曲线的5大预警机制,为儿童健康管理提供技术支…

作者头像 李华
网站建设 2026/4/1 6:20:26

为什么越来越多的网工运维转行网络安全?

为什么越来越多的网工运维转行网络安全? 、 最近越来越多的网工运维小伙伴都在吐槽:干网工、运维多年,薪资还是5.6K,技术也遇瓶颈上不去,考虑转岗或者转行。其中大部分的网工运维小伙伴们纷纷瞄准了高薪高前景的网络…

作者头像 李华