最新资讯

  • 【Linux网络#13】:网络层(IP 协议 & 网络通信 & 全球网络 & 路由转发)

【Linux网络#13】:网络层(IP 协议 & 网络通信 & 全球网络 & 路由转发)

2025-04-28 05:37:18 0 阅读

📃个人主页:island1314

🔥个人专栏:Linux—登神长阶

⛺️ 欢迎关注:👍点赞 👂🏽留言 😍收藏 💞 💞 💞
最后的最后,这里送大家一句话,希望大家于2025年一起奋斗,诸君共勉 💫

  • 生活总是不会一帆风顺,前进的道路也不会永远一马平川,如何面对挫折影响人生走向 – 《人民日报》

🔥 目录

    • 一、前言🔥
    • 二、IP 协议
      • 1. 基本概念
      • 2. 关于 IP
      • 3. IP协议头格式
    • 三、网络通信
      • 1. IP地址的划分理念
      • 2. 什么是子网❓
      • 3. 网络划分
          • 基本概念
          • 分类划分法
          • 广播地址 vs 多播地址
        • 4. CIDR无分类地址解决方案
          • 子网掩码
          • 小结
      • 5. IP 地址的数量限制
      • 5. 私有IP vs 公网IP
      • 6. IP 报文分片 和 重组
    • 四、全球网络
      • 1. 了解运营商
      • 2. 路由器功能
      • 3. 运营商网络架构
      • 4. 数据包的转发流程
      • 5. 路由器的 IP 结构
      • 6. 网络拓扑结构
    • 五、路由转发
      • 1. 概述
      • 2. 路由转发算法
      • 3. 路由转发流程
        • 专业术语版路由转发流程
        • 生动比喻版:快递分拣中心的奇幻漂流 📦🚚
          • Mermaid流程图
          • 术语对照表
          • 特殊场景小剧场


一、前言🔥

🕸️ 之前,我们在这篇 【Linux】: 传输层协议 TCP 已经讲了关于 传输层上,TCP 究竟做了什么,那么实际在网络层中,tcp究竟做了什么,ip 又扮演了什么角色?

现在,我们来看下面一个小故事,方便我们对后面的理解,如下:

张三老爹是教务处主任他要求张三每次数学考试都考100分,张三也很争气,10次数学考试8次都是100分,但是架不住意义可能考了95分。而张三老爹每次必须让张三数学考100分,那张三老爹怎么办呢?他决定之前考试作废,重新考试,如果张三还没有考到,那考试继续作废,直到张三考到100分。

刚才我们两个人,一个教务处主任(张三老爹),张三(儿子)。考试的是张三,他也有能力考到100分,但并不一定每次都考到100。张三没考到没事他还有他老爹,他可以让他儿子继续考。

  • 张三老爹:tcp 协议,提供可靠性
  • 张三:IP ,真正办事的
  • IP 协议的本质:1. 定位主机 2.提供一种能力,将数据跨网络从 A 主机送到 B 主机
  • 用户需要的是:可靠的送到能力
  • 老爹(tcp 可靠策略)+ 张三(ip 传输能力)
  • 只有 策略+能力 才能一定能做到将数据从主机A可靠的跨网络送到主机B。

因此现在我们可以知道,前面 tcp 学的超时重传、确认应答、流量控制等等全都是策略!而具体怎么做全部都是由 ip 来执行!

二、IP 协议

1. 基本概念

 主机: 配有 IP 地址, 但是不进行路由控制的设备;
 路由器: 即配有 IP 地址, 又能进行路由控制;
 节点: 主机和路由器的统称;

2. 关于 IP

  • 目的:要对所有的主机进行的唯一标识,全球内具有唯一性的 IP(公网 IP),每个主机都要有自己的 IP
  • 源 IP:源主机 (localhost)
  • 目的 IP:目的主机 (destination)

比如上面图中,主机B 要到达 主机C,它两并不是直接连接的,下面补充两个问题

  • 凭什么要交给下一跳 route(为什么):网络层 IP 决定的
  • 怎么把数据交给路由器(怎么办):进行局域网通信
  • 因此我们可以知道相当于无数个局域网通信构成了主机 B 到主机 C 的广域网通信

因此我们可以得到一个小结论: IP = 目标网络+目标主机

举个例子,就比如我们要去旅游,如果要去目标城市 --> 就需要经过一些目标地点(高铁站、酒店 …),最后到达我们最后目的地

  • 路径选择中,目标IP决定了我们的路径该如何走。
  • 相当于是拿着目的 IP,主机——>进行路径选择路由器——>目标主机

因此我们可以得到一个结论:这是一套精心设计过的网络体系!

3. IP协议头格式

在学习任何网络协议之前,需要先理解以下两个基本问题:

  1. 如何将报头和有效载荷分离?
  2. 如何交付?

IP 报头与有效载荷分离

  • IP报头选项:IP报头可以包含选项字段,但本文不讨论这些选项。
  • 标准长度:IP报头的标准长度是20字节。
  • 数据组成:数据部分(即有效载荷)由上层TCP提供,它包括TCP报头和来自应用层的有效载荷。

分离方法
(第一层:

  • 4位版本号(version):指定 IP 协议版本,对于IPv4来说总是4。注意:IPv4和IPv6之间没有直接兼容性。
  • 4位首部长度(header length):表示IP报头总长度,单位为4字节。取值范围是【5, 15】(对应于20到60字节),其中5是最常见的值,代表20字节。
  • 16位总长度(total length):指整个IP报文的长度,包括报头和有效载荷。
  • 8位服务类型(Type Of Service):
    • 包括已废弃的3位优先级字段、4位ToS字段以及1位保留位(必须设为0)。
    • ToS字段定义了服务质量参数如最小延迟、最大吞吐量、最高可靠性和最低成本。
    • 这些参数互斥,选择其中之一影响数据传输路径的选择标准。
  • 计算公式:有效载荷长度 = 16位总长度 - (4位首部长度 * 4)

为什么需要16位总长度?

 确保接收方完整地接收到整个IP报文。
因为IP报文是以独立报文形式存在,并非像TCP那样的连续字节流,因此需要明确标示出报头和有效载荷的具体长度。

(第二层:涉及到 IP 报文和分片(后面会讲)

  • 16 位标识(id): 唯一的标识主机发送的报文. 如果 IP 报文在数据链路层被分片了, 那么每一个片里面的这个 id 都是相同的.
  • 3 位标志字段: 第一位保留(保留的意思是现在不用, 但是还没想好说不定以后要用到). 第二位置为 1 表示禁止分片, 这时候如果报文长度超过 MTU, IP 模块就会丢弃报文. 第三位表示"更多分片", 如果分片了的话, 最后一个分片置为 0, 其他是 1. 类似于一个结束标记.
  • 13 位分片偏移( framegament offset): 是分片相对于原始 IP 报文开始处的偏移, 其实就是在表示当前分片在原报文中处在哪个位置, 实际偏移的字节数是这个值 8得到的。 因此 除了最后一个报文之外, 其他报文的长度必须是 8 的整数倍(否则报文就不连续了)

如何交付
(第三层:

  • 8位生存时间(Time To Live, TTL):定义了数据报到达目的地前允许经过的最大跳数。通常初始化为64,每经过一个路由器TTL减1,直至归零仍未达目的地则被丢弃。此字段 防止出现路由环路

  • 8位协议字段:标识了上层协议类型。当发送时,上层会告知IP所使用的协议,然后IP设置相应的编号。接收方根据这个字段将数据传递给正确的上层协议处理

  • 16位头部校验和:使用 循环冗余 校验( CRC )来检测头部错误。如果发现损坏,则丢弃该包,TCP随后会触发重传机制。

  • 32位源/目的IP地址:指定数据报的起点和终点。特别是目的IP地址,用于路由器确定下一跳路径。

三、网络通信

引入:

 路由器的工作只在网络层,没有 tcp 层。只有两台主机有 tcp 层,src_ip:src_port(进程)->dst_ip: dst_port(进程)

1. IP地址的划分理念

背景说明:

互联网上的所有IP地址都是经过精心设计和规划的。
强调理解IP地址网段划分及子网划分的重要性,不应仅停留在对子网掩码等技
细节的理解上,而要从更宏观的角度去认识这一过程。

宏观理解:

  • 从全球到国家、地区乃至具体机构或学校,IP地址的分配体现了这种层次化的结构。每个层级都可以看作是一个更大范围内的“子网”。
  • 不同区域使用不同的比特位来表示,使得整个IP地址体系具有清晰的层次性和区域性。
  • 类比学号系统,每个部分代表了不同级别的信息(如年级、班级、个人编号)

复杂性与挑战:

  • 实际的IP地址划分非常复杂,而且随着互联网的发展,IPv4地址资源已经变得紧张。
  • 尽管面临资源限制,但基本的设计思想是一致的,即通过合理分配来最大化利用现有地址空间。
  • 解决方案并非简单粗暴地进行划分,而是采用了更为精细的方法和技术。

具体网络划分:

  • 网络一旦被划分为不同的网段,每台主机都将归属于特定的一个网段。
  • 寻址时首先确定目标主机所在的网段,再在该网段内定位具体的主机。
  • 因此,一个完整的IP地址由两部分组成:网络号+主机号
    • 网络号:用于标识不同的网段,确保互连的不同网段之间具有唯一性。
    • 主机号:在同一网段内,各主机共享相同的网络号,但各自拥有唯一的主机号以区分彼此。

路由器的作用:

  • 路由器作为连接两个或多个子网的关键设备,在数据包转发过程中起到桥接作用。
  • 它同时属于所连接的所有子网,并且在每个子网中都拥有自己的IP地址
  • 通常是 == 该子网 网络号+.1的形式(例如,对于网络192.168.1.0/24,路由器可能配置为192.168.1.1)

2. 什么是子网❓

子网是由一组网络号相同的主机组成的集合

  • 新增主机到某一子网时,其网络号需与该子网一致,但主机号必须保证在整个子网范围内唯一。
  • 通过这样的方式,可以确保即便是在相互连接的不同网络中,也能够保持每台主机IP地址的独特性,从而避免冲突。

那么子网是怎样进行管理的呢??

问题背景:

  • 手动管理子网内的IP是一个相当麻烦的事情。例如,当子网内有主机离开或新加入时,就需要对子网内的IP地址进行相应的增删改操作。这项管理工作通常由谁来完成呢?

管理设备:在一个子网中,负责管理子网内IP的通常是路由器。

自动管理解决方案

  • DHCP技术:为了解决手动管理IP带来的不便,有一种叫做DHCP(Dynamic Host Configuration Protocol)的技术被开发出来,它能够自动地给子网内的新增主机节点分配IP地址。
  • 路由器与DHCP:大多数现代路由器都内置了DHCP功能,因此路由器也可以被视为一个DHCP服务器。
  • DHCP服务描述:DHCP是一种自动化服务,负责网络中的IP地址申请、分配和回收等管理工作。
    上网前获取IP:这也是为什么我们的电脑在上网之前需要先连接到路由器的原因之一——为了通过路由器获得一个可用的IP地址,从而接入互联网。

3. 网络划分

基本概念

🤪 我们来讲一个小故事,背景如下:

 每个学校都有很多学院如计算机学院、理学院、化工学院、机械学院、电子信息工程学院等等,每个学生也都有自己的学号,这个学号其实是经过精心设置的。这里我们简化一下把 学号 分成 学院号+自己所在院系内的编号。每个学院也都有自己的编号。

 每一个学院都有自己院学生会主席并且他还是院群里面的群主,而且他也有属于自己的学号。并且这个学号在全校范围内唯一。每个院学生会主席都还要在加一个校学生会主席群。

事件如下:
 今天电子信息工程学院的一名普通学生李四同学把自己学生证丢了,学生证上面其他信息都模糊看不清了,只有学号(101 00101)可以看得清。
 然后计算机学院张三同学(学号:000 01001)在校园内捡到这个学生证。张三同学就想把学生证归还给该同学,但这个学生证只有 学号 看的请。可是张三除了自己院学生号清楚并不清楚其他院的学号。

方法如下:
 他知道 学号在全校范围内唯一,他要找这个人,因此张三就在食堂门口抓住一个人就问同学你的学号

查找本质是在做排除。如果进行线性遍历,效率太低了,所以就有了我们的方法二,如下:

  • 张三把这张学习卡拍张照片放到院群里@一下院学生会主席王五,他知道王五可以对接外部。然后让王五到校学生会群中去找,确定这个同学是哪个院的

因此我们可以从上例知道:网络通信本质是把数据交给目标主机

 张三:源主机
 李四:目表主机
 院学生会主席:路由器
 院内的群:局域网
 校学生会群:公网

捡到的李四钱包中的学号(ip):学院(目标网络)+学号(目标主机)

补充知识:路由器,认识主机,认识网络目标中的转接,局域网到公网中的查找

为什么第二种方法这么快?因为一次排除一群,排除的效率更高。通过校学生会可以直接锁定了电信学院,排除了其他学院,相当于进行了 网络划分

IP地址分为两个部分,网络号和主机号:

  • 网络号:保证相互连接的两个网段具有不同的标识。
  • 主机号:同一网段内的主机,具有不同的主机号。

根据网络号查找目标网络,进入目标网络后,再查找并对比IP中的主机号,就确定了目标主机。

分类划分法

最开始时提出一种划分网络号和主机号的方案,把所有IP地址分为五类,如下图所示: 如下图所示
(该图出 自[TCPIP])

什么是 A、B、C 类地址?

其中对于 A、B、C 类主要分为两个部分,分别是网络号和主机号。这很好理解,好比小林是 A 小区 1 栋 101 号,你是 B 小区 1 栋 101 号。

我们可以用下面这个表格, 就能很清楚的知道 A、B、C 分类对应的地址范围、最大主机个数。

那么 A、B、C 分类地址最大主机个数是如何计算的呢?

 最大主机个数,就是要看主机号的位数,如 C 类地址的主机号占 8 位,那么 C 类地址的最大主机个数:2^8-2=254

为什么要减 2 呢?

  • 因为在 IP 地址中,有两个 IP 是特殊的,分别是主机号全为 1 和 全为 0 地址。
  • 主机号全为 1 指定某个网络下的所有主机,用于广播
  • 主机号全为 0 指定某个网络

因此,在分配过程中,应该去掉这两种情况

什么是D、E类地址?

  相比于上面的 A、B、C类, D 类和 E 类地址是没有主机号的,所以不可用于主机 IP,D 类常被用于多播,E 类是预留的分类,暂时未使用。

广播地址 vs 多播地址

① 广播地址用于什么?
 广播地址用于在同一个链路中相互连接的主机之间发送数据包。

广播地址可以分为本地广播和直接广播两种。

  • 在本网络内广播的叫做 本地广播
    • 例如网络地址为 192.168.0.0/24 的情况下,广播地址是 192.168.0.255 。
    • 因为这个广播地址的 IP 包会被路由器屏蔽,所以不会到达 192.168.0.0/24 以外的其他链路上。
  • 在不同网络之间的广播叫做 直接广播
    • 例如网络地址为 192.168.0.0/24 的主机向 192.168.1.255/24 的目标地址发送 IP 包。
    • 收到这个包的路由器,将数据转发给 192.168.1.0/24,从而使得所有 192.168.1.1~192.168.1.254 的主机都能收到这个包(由于直接广播有一定的安全问题,多数情况下会在路由器上设置为不转发。)

② 多播地址用于什么?
 多播用于将包发送给特定组内的所有主机。

多播使用的 D 类地址,其前四位是 1110 就表示是多播地址,而剩下的 28 位是多播的组编号。

从 224.0.0.0 ~ 239.255.255.255 都是多播的可用范围,其划分为以下三类:

  1. 224.0.0.0 ~ 224.0.0.255 为预留的组播地址,只能在局域网中,路由器是不会进行转发的。
  2. 224.0.1.0 ~ 238.255.255.255 为用户可用的组播地址,可以用于 Internet 上。
  3. 239.0.0.0 ~ 239.255.255.255 为本地管理组播地址,可供内部网在内部使用,仅在特定的本地范围内有效。

IP分类的缺点

缺乏地址层次性: 在同一网络中使用了B类地址,但是无法按照生产、测试、开发等环境来划分地址层次。这种情况下,缺少地址的层次性划分,使得IP地址的管理和分配缺乏灵活性和有效性。

A、B、C类地址的限制

虽然上面分类很好,但是随着 Internet 的飞速发展,这种划分方案的局限性很快显现出来大多数组织都申请 B 类网络地址, 导致 B 类地址很快就分配完了, 而 A 类却浪费了大量地址;

  • B类地址由于需求大而迅速耗尽。
  • A类和B类地址造成大量IP资源浪费。

例如,一个B类地址理论上允许单个子网内存在超过65,000台主机;而A类则更多。然而实际网络架设中很少有网络需要如此多的地址空间,导致许多分配出去的地址并未得到充分利用。

  • 而C类地址主机数量少: C类地址只能容纳最多254个主机,对于需要较多IP地址的场景,数量明显不足。
4. CIDR无分类地址解决方案

为解决上述问题,提出了CIDR机制

  • CIDR(Classless Inter-Domain Routing,无分类域间路由)是一种现代的IP地址分配和路由技术,它取代了传统的A类、B类、C类地址的分类方式。

  • CIDR允许网络管理员更加灵活地分配IP地址,有效地利用IP地址空间。

  • 网络号与主机号的界限不再依赖于IP地址类型(A/B/C),此时网络号和主机号的划分与这个 IP 地址是 A 类、B 类还是 C 类无关

CIDR地址表示通常采用IP地址加上斜线后跟随的子网掩码位数,比如 10.100.122.2/24,这种地址表示形式就是 CIDR,/24 表示前 24 位是网络号,剩余的 8 位是主机号。


10.100.122.2/24 表示IP地址为 10.100.122.2,属于一个使用子网掩码 /24 的网络,该网络的范围是 10.100.122.010.100.122.255,可以支持最多254台主机连接(因为0和255分别是网络地址和广播地址,不能用于主机)

子网掩码

还有另一种划分网络号与主机号形式,那就是子网掩码,掩码的意思就是掩盖掉主机号,剩余的就是网络号。

  • 子网掩码是一个32位数字,通常尾部由一系列 0 组成。
  • 将子网掩码和 IP 地址按位&计算,就可得到网络号

子网掩码用于将IP地址分成网络部分和主机部分。对于IP地址 10.100.122.2/24,子网掩码 /24 表示前面24位是网络部分,后面8位是主机部分。

现在让我解释一下如何计算子网掩码和网络地址:

  • 将IP地址和子网掩码进行逻辑与操作,以确定网络地址。
  • 将IP地址 10.100.122.2 和子网掩码 255.255.255.0 进行与操作:
IP地址:   00001010.01100100.01111010.00000010
子网掩码: 11111111.11111111.11111111.00000000
----------------------------------------------
网络地址:  00001010.01100100.01111010.00000000
最终得到的网络地址是 10.100.122.0
小结

目的IP & 当前路由器的子网掩码 = 该报文要去的目的网络

  • 每个路由器需为其连接的每个网络设定相应的子网掩码。
  • 不同路由器至少要链接两个不同网络。
  • 利用目标IP地址与当前路由器子网掩码做与运算可识别报文的目标网络。

在上面我们知道可以通过子网掩码划分出网络号和主机号,那实际上子网掩码还有一个作用,那就是划分子网。

子网划分实际上是将主机地址分为两个部分:子网网络地址 和 子网主机地址

  • 未做子网划分的 ip 地址:网络地址+主机地址
  • 做子网划分后的 ip 地址:网络地址+(子网网络地址+子网主机地址)

下面我们再来看看子网划分的例子,如下:
【案例1】:

例如上面的 IP 地址:140.252.20.68/24

  • 表示IP地址为140.252.20.68
  • 子网掩码的高24位是1,也就是255.255.255.0
  • 网络号占据24个比特位

【案例2】:

225.225.255.240 前面28位是网络号,后面4位是主机号~计算思路如下

可见,IP地址与子网掩码做与 & 运算可以得到网络号,主机号从全0到全1就是子网的地址范围

特殊的 IP 地址

  • 将 IP 地址中的主机地址全部设为 0, 就成为了网络号, 代表这个局域网;
  • 将 IP 地址中的主机地址全部设为 1, 就成为了广播地址, 用于给同一个链路中相互连接的所有主机发送数据包;
  • 127.*的 IP 地址用于本机环回(loop back)测试,通常是 127.0.0.1

local 设备如下:

5. IP 地址的数量限制

我们知道, IP 地址(IPv4)是一个 4 字节 32 位的正整数。 那么一共只有 2 的 32 次方 个 IP地址大概是 43 亿左右,而 TCP/IP 协议规定每个主机都需要有一个 IP 地址.

那么这是不是意味着一共只有 43 亿台主机能接入网络❓

实际上由于一些特殊的 IP 地址的存在数量远不足 43 亿;另外 IP 地址并非是按照主机台数来配置的,而是每一个网卡都需要配置一个或多个 IP 地址.

此时, CIDR 在一定程度上缓解了 IP 地址不够用的问题(提高了利用率, 减少了浪费, 但是 IP 地址的绝对上限并没有增加),仍然不是很够用。这时候有三种方式来解决:

  1. 动态分配 IP 地址: 只给接入网络的设备分配 IP 地址. 因此同一个 MAC 地址的设备, 每次接入互联网中, 得到的 IP 地址不一定是相同的;
  2. NAT(网络地址转换) 技术:允许内部网络中的多台计算机共享一个或几个公共IP地址访问外部网络。(后面会重点介绍)
  3. IPv6: IPv6使用16字节(128位)表示一个IP地址,极大地扩展了地址空间。
    • 注意:IPv6与IPv4不兼容,属于完全不同的协议体系。
    • 尽管IPv6提供了足够的地址空间解决IPv4地址耗尽的问题,但截至当前,IPv6尚未广泛普及(原因:两者不能相互兼容,因此不但要我们电脑、手机之类的设备支持,还需要网络运营商对现有的设备进行升级)

IPv4 首部与 IPv6 首部的差异如下图:

Pv6 相比 IPv4 的首部改进:

  • 取消了首部校验和字段。 因为在数据链路层和传输层都会校验,因此 IPv6 直接取- 消了 IP 的校验。
  • 取消了分片/重新组装相关字段。 分片与重组是耗时的过程,IPv6 不允许在中间路由器进行分片与重组,这种操作只能在源与目标主机,这将大大提高了路由器转发的速度。
  • 取消选项字段。 选项字段不再是标准 IP 首部的一部分了,但它并没有消失,而是可能出现在 IPv6 首部中的「下一个首部」指出的位置上。删除该选项字段使的 IPv6 的首部成为固定长度的 40 字节。

NAT是现在内网到公网上数据转发的主流技术。目前我们用IPv6也能访问公网也是用的类似技术

现在我们知道IP地址可以被分成内网IP和公网IP,那么哪些是内网IP?哪些又是公网IP?

那网络既有内网又有公网我们该如何理解呢?

5. 私有IP vs 公网IP

如果一个组织内部组建局域网,IP地址只用于局域网内的通信,而不直接连到Internet 上,理论上 使用任意的IP地址都可以,但是RFC 1918规定了用于组建局域网的私有IP地址,如下:

IP网络号地址数
10.*/前8位共16,777,216个地址
172.16./12 ~ 172.31./前12位共1,048,576个地址
192.168.*/前16位共65,536个地址

注意:只能用上面这三类来组建局域网,而包含在这个范围中的,都称为私有IP。 其余的则称为全局IP(或公网IP)

因此之前我们经常说IP地址具有唯一性,通常谈的是 全局IP 或者说是 公网IP

  • 在大家前 18 年的使用生涯中,都在直接使用的其实都是私有 IP
  • 云服务器就接触到了–公网 IP

验证:ipconfig 查看

公网IP在整个网络都不能重复,但私网IP在不同网段内是可以重复的。

公有 IP 地址由谁管理呢?

  • 私有 IP 地址通常是内部的 IT 人员管理,公有 IP 地址是由 ICANN 组织管理,中文叫「互联网名称与数字地址分配机构」。
  • IANA 是 ICANN 的其中一个机构,它负责分配互联网 IP 地址,是按州的方式层层分配。

6. IP 报文分片 和 重组

🤔 为了讨论 IP 报文的分片问题,我们先思考一下为什么 TCP 协议中滑动窗口中的数据,不打包成一个报文发送呢?为什么要一段一段的发?

首先,传输层要依次将报文向下层发送(数据段–>数据报–>数据帧),由于数据链路层规定,单次发送数据帧的有效载荷不能超过 MTU(最大传输单元,以太网的 MTU 是 1500 字节),当一个 IP 数据报的大小超过了网络的 MTU 限制时,就需要进行分成多个数据包交给链路层(分片)!

所以,当 IP报文太长时,要进行分片;但是谁来分片呢?网络层自己分,因此网络层报头中多了3个字段。

首次我们要明确一下,分片是好还是不好呢?

不好,丢包概率增加了

  • 传输层向下发送一个X大小的报文段,对端传输层就只关心收到的报文段大小是不是X,它不关心是否分片了
  • 分片以后,发送的包更多了,丢包的概率增加了;对端网络层无法对包进行组装,因此就会被传输层判定为丢包。
  • 所以,丢包不仅仅是在“路上”丢,也有可能是分片后导致拼不起来了,造成丢包

所以,分片不能作为网络发送的主流,那如何不分片呢?

  • 网络层不要发太长的报文,但是网络层决定不了,真正决定发多少的是传输层,所以问题的根源就是传输层不要发太长的报文段,所以滑动窗口才会一段一段的发(它考虑了分片的问题)

结论:

  • 分片会提高报文丢失的风险,所以一般不分片。传输层控制会报文的大小,这样IP层就不需要分片。
  • 一旦数据包丢失,所有数据包都会丢弃,反映到传输层就是触发重传。

分片和组装都是IP协议的任务

分片
① 检查 MTU 限制:

  • 当一个 IP 数据报的大小超过了网络的 MTU(最大传输单元) 限制时, 就需要进行分片。 MTU 是数据链路层对 IP 层数据包进行封装时所能接受的最大数据长度。

② 分割数据报:

  • IP 层将原始的 IP 数据报分割成多个较小的片段。
  • 对于每个片段, IP 层会设置相应的标识(Identification) 、 偏移量(Fragment Offset) 和标志位(Flags) 等字段。
  • 标识字段用于标识属于同一个数据报的不同分片, 确保所有分片能够被正确地重新组装。
  • 偏移量字段指示了当前分片相对于原始数据报的起始位置, 以 8 字节为单位。
  • 标志位字段包含了 3 个位, 其中 MF(More Fragment) 位用于指示是否还有更多的分片, DF(Do Not Fragment) 位用于指示数据报是否允许进行分片。

③ 添加 IP 头部:

  • 每个分片都会加上自己的 IP 头部, 与完整 IP 报文拥有类似的 IP 头结构, 但 MF 和 Fragment Offset 等字段的值会有所不同。

④ 发送分片:

  • 分片在传输过程中独立传输, 每个分片都有自己的 IP 头部, 并且各自独立地选择路由。

组装

  • 接收分片:当目的主机的 IP 层接收到这些分片后, 会根据标识字段将属于同一个数据报的所有分片挑选出来。
  • 排序与组装:利用片偏移字段, IP 层会对属于同一个数据报的分片进行排序。
    • 当所有的分片都到达并正确排序后, IP 层会将这些分片重新组装成一个完整的 IP 数据报。
  • 传递给上层协议:组装好的 IP 数据报会传递给上层的协议进行处理。

注意:

  • IP 分片对传输层是透明的,这意味着传输层无需关心数据是否被分片以及如何重新组装。
  • 接收方如何得知自己收到的报文分片了?
  • 接收方如何得知自己收到的分片收全了?
  • 接收方如何组合形成完整的报文?

那么这里就要讲讲:

字段解释
16位标识报文的标识各不相同,分片报文的标识是一致的,可以根据标识查找分片的报文
13位片偏移片偏移表示分片报文的有效载荷距原始有效载荷起始位置的偏移量
3位标志1位保留,1位禁止分片,1位更多分片:为1表示中间报文,为0表示为结尾报文

在网络传输过程中,可能会发生分片丢失的情况。

假设原始数据包的大小为 3020 字节,MTU 为 1500 字节,那么分片丢失情况如下:

第一个分片:

  • 此时 16位标识:6666
  • 更多分片:1
  • 片偏移:0
  • 大小:1480字节(1500字节MTU - 20字节IP头)

第二个分片(中间分片):

  • 16位标识:6666
  • 更多分片:1
  • 片偏移:185(1480字节 / 8字节,向上取整)
  • 大小:1480字节

第三个分片:

  • 16位标识:6666
  • 更多分片:0
  • 片偏移:370(2960字节 / 8字节,向上取整)
  • 大小:60字节(3020字节 - 2*1480字节)

此时假设第一个丢了 那么片偏移为 0 的分片就没有了,能判断出分片丢失,如果中间的丢了 那么片偏移也对不上,如果最后一个丢了 那么更多分片为 0 的结尾没了,也能判断出分片丢失,这也就解决了接收方如何确定自己收到收全了

结论:如果报文丢失了,如何检验呢?

  • 如果没有查找到片偏移为0的报文,就说明首位报文丢失。
  • 如果当前报文片偏移加上报文长度不等于下一个报文的片偏移,则说明中间报文丢失。
  • 如果3位标志中最后一位为0,表示当前报文就是结尾报文。

比如:一个3420字节的IP报文,可以分成3个分别是1480、1480、440,再给加上报头即可

接收端如何判断收到的报文是普通报文还是分片报文?

  • 如果片偏移(MF)不为零,一定是分片报文,
  • 如果片偏移为(MF)0,但3位标志最后一位为1,则一定是分片报文;
  • 除此以外,都是普通报文。

分片与组装流程如下:

分片细节补充:
① 有效载荷的分片

  • IP报文的有效载荷是进行分片的主要对象。分片时,数据包被分割成多个片段,每个片段都包含一部分原始数据。

② 片偏移

  • 片偏移是指每个分片相对于原始IP报文有效载荷的开始位置的偏移量。这个偏移量必须是8字节的整数倍,因为IP分片的偏移量字段以8字节为单位。

③ 分片包含IP报头

  • 每个分片都是一个完整的IP报文,这意味着每个分片都包含自己的IP报头。这样做是为了确保即使在分片过程中发生错误,每个分片也能够被正确地路由和处理。

四、全球网络

我们可以在 IPSHU 上查看全球 IP 的使用情况

1. 了解运营商

背景:当我们想在家中上网时,如果我们已经使用了某个运营商的手机卡,只需要打电话给运营商,联系其安装网络的师傅来安装。

他们通常会带来一个调制解调器(俗称“猫”)和一个路由器,安装人员会将网络账号与密码设置好,接着配置无线网络名称和密码,这样,家里的设备就可以通过WiFi上网了。

网络基础设施的来源

  • 上网的网线是运营商提供的。这意味着运营商已经在你家附近建设了网络基础设施。
  • 当你通过路由器发起网络请求时,信息会携带你的网络账号和密码,这个请求首先会到达运营商的服务器,由他们认证你是否欠费。
  • 如果没有欠费,运营商就会将请求继续传递到你所请求的服务,比如腾讯、阿里、百度等。

因此,运营商实际上位于用户和互联网服务提供商之间,扮演着基础设施建设者的角色。

网络访问的控制

 运营商有权限制你的网络访问,尤其是当你欠费时,他们可以阻止你的数据报文的转发。除此之外,运营商也可以审核你的上网内容。

例如,发现你尝试访问谷歌、推特等被限制的网站时,运营商可以选择不转发你的请求。

  • 这种机制通常被称为“墙”,而“翻墙”实际上是绕过运营商的转发限制。
  • 物理上,用户不可能绕过运营商直接访问互联网服务提供商(如字节跳动),因为没有直接连接的通路。

在网络架构上,用户必须 经过运营商的网络才能访问外部互联网服务

2. 路由器功能

主要功能

  • 转发数据:路由器的核心任务是转发网络数据包。
  • DHCP:动态主机配置协议,自动为局域网中的设备分配IP地址。
  • NAT:网络地址转换技术,用于将内部局域网IP转换为可在公网使用的IP地址。

组建局域网

  • 路由器可以用来创建局域网,配置无线网络时,我们可以设置网络名称和密码。
  • 在这种网络中,路由器使用内网IP,比如家用路由器通常使用192.168.*
  • 企业级路由器可能使用10.*或172.16-172.31范围的内网IP。

在上网过程中,通常会遇到两种密码:

  1. 一种是用于连接互联网服务提供商(ISP)的账号密码
  2. 另一种是用于访问无线路由器设置或连接到家庭Wi-Fi网络的密码。这两种密码的功能和用途不同。

解释:
① 上网账号密码:这是你向互联网服务提供商申请宽带服务时获得的一组账号信息。

  • 这组信息通常包括一个用户名(可能是你的手机号码或者ISP提供的特定账号名)和对应的密码。
  • 当你首次设置宽带连接或需要重新配置网络连接时,就需要使用这套账号密码来验证身份,并建立与ISP之间的连接。
  • 这个账号密码是用来认证你作为合法用户的凭证,确保只有付费用户能够接入互联网服务。

② 路由器账号密码:实际上这里可以分为两个部分:

  • 路由器管理界面登录密码:允许你访问路由器的Web管理界面,在那里你可以更改各种设置,比如修改Wi-Fi名称、设定安全级别等。
  • Wi-Fi密码:也称为“预共享密钥”(PSK),是指当设备尝试加入你的无线局域网时所需输入的密码。它保护了你的无线网络免受未经授权的访问者侵入。

因此我们可以知道:如果邻居能够蹭网,则意味着他们知道了你的Wi-Fi密码。这是因为只要知道正确的Wi-Fi密码,任何人都可以连接到你的无线网络上。

3. 运营商网络架构

每个家庭都有自己的路由器,负责创建家庭局域网,使用 192.168.* 开头的内网IP。当家庭网络连接到互联网时,需要通过运营商的网络。所以家庭路由器实际上跨越了两个子网:

  1. 家庭局域网子网(192.168.*)
  2. 运营商的子网

结论:这意味着当数据从家用路由器发出时,先到达运营商的子网,再经过多级路由器,最终转发到公网。

家庭路由器会配备两个IP地址:

  1. LAN口IP:用于家庭内部局域网,通常为192.168.*。
  2. WAN口IP:用于连接运营商的网络,是由运营商分配的IP地址。

同理,运营商的路由器也具有LAN口IP和WAN口IP:

  • LAN口IP:用于运营商内部网络(可能是私有网络)。
  • WAN口IP:这是一个公网IP,用于连接到互联网。

4. 数据包的转发流程

  • 在不同局域网中,私有IP是可以重复的,因为只需要在局部环境中保证唯一性。

然而,这带来了一个问题:当不同局域网中的设备使用相同的IP地址(例如,192.168.1.201)时,外部服务提供商(如抖音)如何知道数据包应该返回到哪个局域网?

  • 为了解决这个问题,NAT(网络地址转换)技术应运而生。
  • 当数据经过路由器时,路由器会将数据包的源IP地址替换为自己的WAN口IP。
  • 当请求返回时,路由器则会根据这个WAN口IP知道将数据包转发到哪个局域网的设备上。

路由器能横跨两个网络,所以要配两个IP,LAN口连接内网,WAN口连接外网。

 IP数据包的传输时,路由器将目的IP与路由表进行对比:

  • 如果对应得上就说明目标主机就在自身子网内,就直接发送到目标主机
  • 如果访问的不是子网内的主机,就将源IP替换成路由器的WAN口IP,也就是将报文转发到外网。

5. 路由器的 IP 结构

个人主机上的 IP 是私有 IP,而且每个路由器都有两个IP地址:

  1. LAN口(子网 IP:用于在局域网内部通信,通常为私有IP(如192.168.1.1)。来实现对上一个的连接
  2. WAN口IP:用于与外部网络(如运营商网络)通信。这个IP可能是一个公网IP。路由器自己的标识

路由器内的主机(如手机、电脑等)使用局域网的IP地址,而这些IP地址在不同的局域网中是可以重复的。

  • 然而,当这些主机需要访问外网时,路由器会使用NAT技术将内部的私有IP地址替换为WAN口IP。这种逐级替换的过程使得最终的数据包在公网中能够使用一个唯一的IP地址进行通信。
  • 如果想要让外界能够访问我们自建的服务器(如网页服务器),那么这台自建服务器必须部署在具有公网IP的设备上。例如,云服务提供商(如阿里云、腾讯云)可以提供这样的服务器。

6. 网络拓扑结构

公网和子网的划分通常可以通过IP地址和子网行。

比如,如果从美国发出一个请求,目标IP地址是湖南长沙的服务器

  • 路由器首先会判断这个IP不属于本地网络,于是将请求发送给国际路由器。
  • 国际路由器再判断目标IP属于中国,就会将数据包转发到中国的路由器。
  • 接下来,中国的路由器会继续判断目标IP,发现属于湖南,再由湖南的路由器转发给长沙的服务器。

整个互联网的拓扑结构虽然复杂,但这种逐级转发的逻辑是其核心。运营商在地方上建立了本地网络,并将不同子网进行划分,然后通过公网入口路由器与全球互联网连接。

网络模式如下,可以看到,在接入长沙之后,由公网入私网

注意:

  • 私有 ip 存在大量重复,不能进公网
  • 路由器会进行报文的替换,WAN 口 IP 的替换
  • 解决:将源 IP 替换成每一个路由器的WAN 口 IP

私有 IP 不断被替换的过程:NAT 技术(后面会讲)
为了解决 IP 不足问题,采取了 互联网 = 公网+私网 的模式

五、路由转发

1. 概述

💤 上面说到,路由器是集连多个子网的设备,子网内的主机如果要访问公网的服务器,其数据需要路由器转发到公网。这就是 路由转发

  • 数据在路由过程中,实际是一跳一跳的(Hop by Hop)“问路”的过程。
  • 所谓“一跳”就是数据链路层中的一个区间,具体在以太网中指从源MAC地址到目的MAC地址之间的帧传输区间


IP 数据包的传输过程:

  • 当 IP 数据包到达路由器时,路由器会先查看目的 IP;
  • 路由器决定这个数据包是能直接发送给目标主机,还是需要发送给下一个路由器;
  • 依次反复一直到达目标 IP 地址;

那么如何判定当前这个数据包该发送到哪里呢?

  • 这个就依靠每个节点内部维护一个 路由表


路由器的查找结果可能有以下三种:

  1. 路由器经过 路由表 查询后,得知该数据应该跳到哪一个子网
  2. 路由器经过 路由表 查询后,没有发现匹配的子网,此时路由器会将该数据转发给默认路由。
  3. 路由器经过 路由表 查询后,得知该数据的目标网络就是当前所在的网络,此时路由器就会将该数据转给当前网络中对应的主机。

Linux路由表可以使用 route 命令查看;Windows下使用 route PRINT -4

  • 如果目的 IP 命中了路由表,就直接转发即可
  • 路由表中的最后一行,主要由下一跳地址和发送接口两部分组成
  • 当目的地址与路表中其它行都不匹配时,就按 缺省路由条目 规定的接口发送到下一跳地址。

route PRINT -4

IPv4 路由表
===========================================================================
活动路由:
网络目标        网络掩码          网关       接口   跃点数
          0.0.0.0          0.0.0.0       10.152.0.1     10.152.19.48     35
       10.152.0.0      255.255.0.0            在链路上      10.152.19.48    291
     10.152.19.48  255.255.255.255            在链路上      10.152.19.48    291
   10.152.255.255  255.255.255.255            在链路上      10.152.19.48    291
        127.0.0.0        255.0.0.0            在链路上         127.0.0.1    331
        127.0.0.1  255.255.255.255            在链路上         127.0.0.1    331

route

lighthouse@VM-8-10-ubuntu:~$ route
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
default         _gateway        0.0.0.0         UG    100    0        0 eth0
10.0.8.0        0.0.0.0         255.255.252.0   U     100    0        0 eth0
_gateway        0.0.0.0         255.255.255.255 UH    100    0        0 eth0
  1. 当一个数据包从源设备发送出去时,它首先会通过源设备的网卡发送到本地网段。

  2. 然后根据目标 IP 地址,源设备的操作系统会查找路由表来确定下一跳的路由器。

    • 路由表中记录了网络的目的地址和相应的下一跳路由器。根据目的地址,源设备会将数据包发送给下一跳路由器。
  3. 下一跳路由器接收到数据包后,会根据自己的路由表,依次与子网掩码Genmask 进行按位与&操作,然后结果与子网掩码对应的目的网络地址 Destination进行对比,如果匹配则将数据发送到这个子网,通过对应的发送接口 Iface 发出。

  4. 这个过程会一直持续,直到数据包到达目标设备所在的网络,并被目标设备接收。如果没有匹配的子网,就会发送到默认路由——default,其对应的 FlagsUG

  • 路由转发过程中,路由器会根据目标地址进行 路由决策,选择最佳路径来转发数据包。
  • 路由器之间通过 路由协议 来交换路由信息,更新各自的路由表,以保证网络中的路由信息能够得到更新和同步。

【案例】:假设某主机上的网络接口配置和路由表如下:

这台主机有两个网络接口:一个网络接口连到 192.168.10.0/24 网络,另一个网络接口连到 192.168.56.0/24 网络

参数介绍:

  • Destination:代表的是目的网络地址
  • Gateway:代表下一跳地址
  • Genmask:代表的是子网掩码
  • Flags:U标志表示此条目有效(可以禁用某些条目);G标志表示此条目的下一跳地址是某个路由器的地址,没有G标志的条目表示目的网络是与本机接口直接相连的网络,不必经由路由器转发
  • Iface:代表的是发送接口

转发过程例 1:如果要发送的数据包的目的地址是 192.168.56.3

  • 跟第一行的子网掩码做与运算得 到 192.168.56.0,与第一行的目的网络地址不符
  • 再跟第二行的子网掩码做与运算得 到 192.168.56.0,正是第二行的目的网络地址,因此从 eth1 接口发送出去;
  • 由于 192.168.56.0/24 正 是与 eth1 接口直接相连的网络,因此可以直接发到目的主机,不需要经路由器转发;

转发过程例 2:如果要发送的数据包的目的地址是 202.10.1.2

  • 依次和路由表前几项进行对比,发现都不匹配:
  • 按缺省路由条目,从 eth0 接口发出去,发往 192.168.10.1 路由器:
  • 由 192.168.10.1路由器根据它的路由表决定下一跳地址;

2. 路由转发算法

路由可分为静态路由和动态路由:

  • 静态路由:是指由网络管理员手工配置路由信息。
  • 动态路由:是指路由器能够通过算法自动建立自己的路由表,并且能够根据实际情况进行调整。

路由表相关生成算法:距离向量算法、LS算法、Dijkstra算法等。

3. 路由转发流程

专业术语版路由转发流程

1. 数据包接收与目标解析

  • 输入接口接收:路由器通过物理接口接收数据包,提取数据链路层帧并解封装至网络层,获取IP数据包。
  • 目标IP提取:解析数据包头部的目标IP地址(Destination IP),作为路由决策依据。

2. 路由表查询与匹配

  • 路由表结构:路由表条目包含以下字段:

    • 目标网络(Destination):CIDR格式(如 192.168.1.0/24)。
    • 子网掩码(Genmask):用于计算目标网络范围。
    • 下一跳地址(Gateway):直接可达的下一路由器IP或本地接口。
    • 出接口(Iface):转发数据包的物理/逻辑接口。
  • 最长前缀匹配(Longest Prefix Match)
    路由器逐条比对目标IP与路由表条目:

    Target IP & Genmask == Destination ?  
    匹配则记录,最终选择掩码最长(最精确)的条目。
    

3. 转发决策与封装

  • 直连网络:若目标IP属于路由器直连子网(如 Iface eth0 对应的 192.168.1.0/24),则直接通过ARP解析目标MAC并转发。
  • 下一跳路由:若非直连网络,选择 Gateway 字段指定的下一跳IP,通过ARP解析其MAC地址。
  • 默认路由(Default Route):若无匹配条目,使用目标为 0.0.0.0/0 的默认路由(Flags UG)。

4. 数据链路层重封装

  • 更新帧头:替换源MAC(出接口MAC)和目标MAC(下一跳或目标主机MAC)。
  • TTL递减:IP头部生存时间(TTL)减1,若为0则丢弃并发送ICMP超时通知。

5. 数据包转发与迭代

  • 出接口发送:通过选定接口转发数据帧至下一跳。
  • 递归路由:下一跳路由器重复上述流程,直至数据包抵达目标网络。

6. 路由协议同步

  • 动态路由协议(如OSPF、BGP):路由器间交换路由信息,更新本地路由表,确保网络拓扑变化时路径最优。
  • 路由收敛:全网路由表状态最终一致,形成无环路转发路径。
生动比喻版:快递分拣中心的奇幻漂流 📦🚚

1. 包裹到站:快递分拣员接单

分拣员(路由器)
“叮咚!收到一个包裹,收件地址是 上海浦东新区张江路888号(目标IP:202.96.128.5)!
——先拆开外层纸箱(数据链路层帧),露出里面的 电子面单(IP头部)。”


2. 查地图:全国分拣路线图(路由表)

智能分拣系统
1️⃣ 扫描地址

  • 对比 《全国分拣地图》(路由表)
    • 北京朝阳区/24 → 直送朝阳分站(直连网络)
    • 广东深圳/16 → 下一站广州中心(下一跳网关)
    • 其他地址 → 默认发往上海总枢纽(默认路由)

2️⃣ 精确匹配
“上海浦东新区属于 202.96.128.0/24 片区!下一站派给 浦东分拣机器人(出接口 eth1)!”


3. 换标签:贴上新快递单(MAC重封装)

分拣机器人

  • 撕掉旧快递单(源MAC:00:1A:3F),贴上 下一站专车标签
    🚛 发车人:浦东分拣中心(MAC:AA:BB:CC)
    🏁 收件车:张江路快递车(MAC:DD:EE:FF )`
  • 包裹寿命减1小时(TTL-1),超时直接销毁!

4. 跨城接力:快递车的全国巡游

上海浦东分拣中心

  • 发现地址属于 张江路888号直管片区(直连网络)!
  • 召唤 最后一公里小货车(ARP解析目标MAC),直达收件人手中!

收件人(目标主机)
“终于收到包裹!拆箱后发现是 猫粮大礼包(HTTP响应),赶紧喂主子!”


5. 动态修路:智能地图更新(路由协议)

分拣中心协作

  • 每天凌晨,全国分拣中心开大会(OSPF邻居同步):
    “报告!杭州到上海的高速修好了,新路线快20分钟!”
  • 实时更新《全国分拣地图》(路由表),避开堵车路段(网络拥塞)!

Mermaid流程图
包裹抵达分拣中心
拆箱读地址
查全国分拣地图
匹配直连片区?
召唤最后一公里货车
是否有专线?
贴专车标签发往下一站
扔进默认通道
下一站分拣中心
收件人签收

术语对照表
技术概念快递世界版
目标IP地址包裹收件地址
路由表全国分拣地图
下一跳网关跨城专线快递车
子网掩码片区划分规则(如“浦东新区/24”)
ARP解析召唤本地送货员
TTL包裹保质期倒计时
OSPF/BGP分拣中心战略合作会议

特殊场景小剧场

场景1:地址不存在(路由黑洞)

ICMP信使
骑着摩托追上快递车,塞一张 拒收通知单
“Error 404:收货地址是火星吗亲?” 🛵✉️❌


场景2:高速堵车(网络拥塞)

分拣中心AI
启动 智能绕路模式(动态路由切换):
“检测到京沪高速瘫痪!所有包裹改走长江水运!” 🚢🗺️


  • 这样解释后,路由转发就像一场精心策划的全国快递接力赛,每个路由器都是智能分拣中心,确保包裹(数据包)精准高效送达! 🌐🚚

通过路由转发机制,网络中的数据包可以在不同的网络之间进行传输,实现了跨网络的通信和互联互通。

★,°:.☆( ̄▽ ̄)/$:.°★ 】那么本篇到此就结束啦,如果有不懂 和 发现问题的小伙伴可以在评论区说出来哦,同时我还会继续更新关于【Linux】的内容,请持续关注我 !!

本文地址:https://www.vps345.com/4323.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge ssh deepseek Ollama 模型联网 API CherryStudio 进程 操作系统 进程控制 Ubuntu python MCP ubuntu llama 算法 opencv 自然语言处理 神经网络 语言模型 数据库 centos oracle 关系型 安全 分布式 fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse harmonyos 华为 开发语言 typescript 计算机网络 numpy adb nginx 监控 自动化运维 阿里云 网络 网络安全 网络协议 django flask web3.py 笔记 C 环境变量 进程地址空间 flutter macos react.js 前端面试题 node.js 持续部署 Dell R750XS 科技 ai java 人工智能 个人开发 rust http spring sql KingBase 银河麒麟 kylin v10 麒麟 v10 spring boot 后端 tomcat ESP32 LDAP websocket pycharm ide pytorch nuxt3 vue3 docker 实时音视频 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 自动化 蓝耘科技 元生代平台工作流 ComfyUI tcp/ip 统信 国产操作系统 虚拟机安装 .net golang gitlab c++ 多线程服务器 Linux网络编程 深度学习 conda pillow json html5 firefox android windows 搜索引擎 kubernetes 容器 学习方法 经验分享 程序人生 github 创意 社区 DeepSeek-R1 API接口 串口服务器 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn Hyper-V WinRM TrustedHosts Docker Compose docker compose docker-compose RTSP xop RTP RTSPServer 推流 视频 kvm 无桌面 命令行 matlab YOLOv8 NPU Atlas800 A300I pro asi_bench mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 ecm bpm Deepseek unity c# ansible playbook udp IIS .net core Hosting Bundle .NET Framework vs2022 es jvm php html 机器学习 chatgpt 大模型 llama3 Chatglm 开源大模型 深度优先 图论 并集查找 换根法 树上倍增 ddos ollama llm zotero WebDAV 同步失败 代理模式 YOLO vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 c语言 面试 性能优化 jdk intellij-idea 架构 机器人 EMQX MQTT 通信协议 运维开发 apache 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 AI Agent k8s jenkins 游戏程序 stm32 物联网 qt 云原生 企业微信 Linux24.04 deepin 宝塔面板 同步 备份 建站 安全威胁分析 vscode 1.86 elasticsearch uni-app 漏洞 bash 学习 医疗APP开发 app开发 Samba SWAT 配置文件 服务管理 网络共享 unity3d 目标检测 计算机视觉 SSH Linux Xterminal 远程连接 豆瓣 追剧助手 迅雷 nas 微信 内存 gitee .netcore postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 vscode ollama下载加速 https kylin aws googlecloud 服务器繁忙 备选 网站 api 调用 示例 银河麒麟桌面操作系统 Kylin OS 国产化 AD域 AutoDL IIS服务器 IIS性能 日志监控 clickhouse maven intellij idea 电脑 腾讯云 prometheus 监控k8s集群 集群内prometheus 远程桌面 git sqlite dubbo chfs ubuntu 16.04 TCP服务器 qt项目 qt项目实战 qt教程 Dify openssl 密码学 模拟退火算法 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP mosquitto 消息队列 智能路由器 外网访问 内网穿透 端口映射 r语言 数据挖掘 数据可视化 数据分析 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 fpga开发 ssl 华为od spring cloud kafka hibernate kamailio sip VoIP 编辑器 根服务器 低代码 AI编程 AIGC AI大模型 大模型入门 大模型教程 webrtc remote-ssh sqlserver 权限 ukui 麒麟kylinos openeuler 微服务 mysql kind android studio ruoyi springboot Nuxt.js jmeter 软件测试 需求分析 规格说明书 minio 远程工作 openEuler big data express okhttp CORS 跨域 雨云 NPS 孤岛惊魂4 恒源云 java-ee tcp RTMP 应用层 microsoft oneapi 大模型微调 open webui web安全 安全架构 华为认证 网络工程师 交换机 开源 爬虫 数据集 ios Headless Linux uniapp mongodb LORA 大语言模型 NLP excel pdf asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 Docker Hub docker pull 镜像源 daemon.json live555 rtsp rtp redis shell visualstudio zookeeper debian WSL win11 无法解析服务器的名称或地址 大数据 v10 软件 armbian u-boot 嵌入式硬件 驱动开发 硬件工程 嵌入式实习 交互 流式接口 URL 代码调试 ipdb ftp av1 电视盒子 机顶盒ROM 魔百盒刷机 单片机 EasyConnect 3d 数学建模 Cline 网络结构图 ecmascript nextjs react reactjs LLM Web APP Streamlit hadoop opensearch helm ssrf 失效的访问控制 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 MI300x DeepSeek openwrt ux 多线程 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 Python 网络编程 聊天服务器 套接字 TCP 客户端 Socket 小程序 svn xrdp string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 游戏服务器 TrinityCore 魔兽世界 开发环境 SSL证书 sysctl.conf vm.nr_hugepages odoo 服务器动作 Server action 其他 能力提升 面试宝典 技术 IT信息化 Cursor 源码剖析 rtsp实现步骤 流媒体开发 virtualenv arm 银河麒麟操作系统 rpc 远程过程调用 Windows环境 直播推流 rsyslog 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 JAVA IDEA Java FTP服务器 媒体 微信公众平台 pygame 小游戏 五子棋 中间件 C语言 ipython idm 联想开天P90Z装win10 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 TRAE vim 压力测试 tailscale derp derper 中转 重启 排查 系统重启 日志 原因 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 mysql离线安装 ubuntu22.04 mysql8.0 统信UOS 麒麟 bonding 链路聚合 僵尸进程 课程设计 cursor MCP server C/S LLM windows日志 Minecraft ci/cd 命名管道 客户端与服务端通信 flash-attention 报错 agi 缓存 gpu算力 负载均衡 unix H3C iDRAC R720xd 华为云 springsecurity6 oauth2 授权服务器 前后端分离 go 硬件架构 系统架构 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 Linux PID XFS xfs文件系统损坏 I_O error 集成学习 集成测试 jar FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 file server http server web server Spring Security 5G 3GPP 卫星通信 rdp 实验 Reactor 设计模式 C++ transformer ffmpeg 音视频 UOS 统信操作系统 yum oceanbase rc.local 开机自启 systemd 1024程序员节 ISO镜像作为本地源 系统安全 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 温湿度数据上传到服务器 Arduino HTTP MNN Qwen pppoe radius hugo eureka arm开发 gaussdb DeepSeek行业应用 Heroku 网站部署 xss 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 jupyter pip next.js 部署 部署next.js ocr AI agent 思科模拟器 思科 Cisco 向日葵 博客 muduo X11 Xming 远程登录 telnet 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 CH340 串口驱动 CH341 uart 485 safari Mac 系统 seatunnel ssh远程登录 历史版本 下载 安装 linux上传下载 鸿蒙系统 健康医疗 互联网医院 图形化界面 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 ui wireshark 测试工具 嵌入式 linux驱动开发 阻塞队列 生产者消费者模型 服务器崩坏原因 vmware 卡死 mac bcompare Beyond Compare HarmonyOS Next laravel vue css less Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 模拟器 教程 ue4 着色器 ue5 虚幻 毕昇JDK grafana 直流充电桩 充电桩 nvidia IPMI junit 命令 浏览器开发 AI浏览器 SEO devops c 开机自启动 rag ragflow ragflow 源码启动 显示管理器 lightdm gdm rabbitmq yaml Ultralytics 可视化 无人机 策略模式 单例模式 ESXi Trae AI代码编辑器 智能手机 NAS Termux 半虚拟化 硬件虚拟化 Hypervisor etl 云服务器 裸金属服务器 弹性裸金属服务器 cuda cudnn anaconda p2p mamba Vmamba micropython esp32 mqtt 游戏机 wsl list 模拟实现 Netty 即时通信 NIO npm EMUI 回退 降级 升级 dify postgresql pgpool 鸿蒙 HTTP 服务器控制 ESP32 DeepSeek DevEco Studio glibc 田俊楠 rocketmq fd 文件描述符 致远OA OA服务器 服务器磁盘扩容 语音识别 ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS HCIE 数通 zabbix Windows 游戏引擎 outlook gpt Qwen2.5-coder 离线部署 jina apt cocoapods xcode HiCar CarLife+ CarPlay QT RK3588 信息与通信 threejs 3D yolov8 中兴光猫 换光猫 网络桥接 自己换光猫 视觉检测 职场和发展 vasp安装 SenseVoice Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 边缘计算 智能硬件 查询数据库服务IP地址 SQL Server Linux的基础指令 W5500 OLED u8g2 MS Materials SSH 服务 SSH Server OpenSSH Server 业界资讯 bat code-server composer 单元测试 功能测试 selenium SVN Server tortoise svn 产测工具框架 IMX6ULL 管理框架 springcloud wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 前端框架 ip 计算机 程序员 firewalld visual studio code 元服务 应用上架 elk Logstash 日志采集 proxy模式 AISphereButler 换源 国内源 Debian rustdesk HAProxy linux 命令 sed 命令 大数据平台 计算机外设 软件需求 银河麒麟高级服务器 外接硬盘 Kylin 微信小程序 网络穿透 echarts 信息可视化 网页设计 gradle 华为机试 具身智能 强化学习 回显服务器 UDP的API使用 vSphere vCenter Java Applet URL操作 服务器建立 Socket编程 网络文件读取 wsl2 程序 编程 性能分析 tensorflow OD机试真题 华为OD机试真题 服务器能耗统计 rust腐蚀 GCC crosstool-ng 框架搭建 dns web Linux find grep deekseek 知识库 CVE-2024-7347 VPS 代理 gateway 智能音箱 智能家居 实战案例 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 实时互动 数据结构 iBMC UltraISO selete 高级IO yum源切换 更换国内yum源 多层架构 解耦 可信计算技术 网络攻击模型 XCC Lenovo 飞书 繁忙 解决办法 替代网站 汇总推荐 AI推理 n8n 工作流 workflow 图像处理 CDN web3 Clion Nova ResharperC++引擎 Centos7 远程开发 分析解读 dba autodl ruby 软件定义数据中心 sddc 微信分享 Image wxopensdk mcu iot 反向代理 wsgiref Web 服务器网关接口 flink IPMITOOL BMC 硬件管理 opcua opcda KEPServer安装 信号 skynet IMM 双系统 GRUB引导 Linux技巧 embedding IPv4 子网掩码 公网IP 私有IP SSH 密钥生成 SSH 公钥 私钥 生成 传统数据库升级 银行 LLMs 单一职责原则 iperf3 带宽测试 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 移动云 鲲鹏 FTP 服务器 ShenTong 宠物 毕业设计 免费学习 宠物领养 宠物平台 redhat 技能大赛 小艺 Pura X ardunio BLE gitea mariadb 自定义客户端 SAS 僵尸世界大战 游戏服务器搭建 nfs SSL 域名 Anolis nginx安装 环境安装 linux插件下载 线程 大大通 第三代半导体 碳化硅 软链接 硬链接 ldap cnn GoogLeNet Typore webstorm 虚拟机 IDE AI 原生集成开发环境 Trae AI VR手套 数据手套 动捕手套 动捕数据手套 文件系统 路径解析 服务器主板 AI芯片 RustDesk自建服务器 rustdesk服务器 docker rustdesk 黑客技术 流水线 脚本式流水线 efficientVIT YOLOv8替换主干网络 TOLOv8 7z 项目部署到linux服务器 项目部署过程 本地部署 pyqt 输入法 DenseNet asm 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 AI-native Docker Desktop CrewAI etcd 数据安全 RBAC Kali Linux 黑客 渗透测试 信息收集 h.264 交叉编译 网卡的名称修改 eth0 ens33 办公自动化 自动化生成 pdf教程 自动驾驶 tidb GLIBC cpp-httplib 网工 云服务 keepalived sonoma 自动更新 远程 执行 sshpass 操作 vscode1.86 1.86版本 ssh远程连接 SSE open Euler dde db 迁移指南 Linux环境 bug chrome devtools chromedriver sqlite3 gcc g++ g++13 信号处理 WSL2 adobe Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 VMware安装Ubuntu Ubuntu安装k8s 软件工程 iis Kali GPU 雨云服务器 token sas 环境迁移 lio-sam SLAM 服务器管理 配置教程 服务器安装 网站管理 崖山数据库 YashanDB pyautogui 视频编解码 Ubuntu 24.04.1 轻量级服务器 NFS k8s集群资源管理 云原生开发 python3.11 dash 正则表达式 合成模型 扩散模型 图像生成 RAGFLOW 序列化反序列化 群晖 文件分享 毕设 ros2 moveit 机器人运动 相差8小时 UTC 时间 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 烟花代码 烟花 元旦 远程控制 远程看看 远程协助 onlyoffice HarmonyOS OpenHarmony 真机调试 Node-Red 编程工具 流编程 知识图谱 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 CPU 架构与原理 AI写作 prompt cpu 实时 使用 王者荣耀 捆绑 链接 谷歌浏览器 youtube google gmail 三级等保 服务器审计日志备份 Ark-TS语言 KylinV10 麒麟操作系统 Vmware 端口 查看 ss 图形渲染 黑苹果 VMware cd 目录切换 sdkman dity make sequoiaDB camera Arduino 电子信息 软考 aarch64 编译安装 HPC 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 nac 802.1 portal alias unalias 别名 多个客户端访问 IO多路复用 TCP相关API prometheus数据采集 prometheus数据模型 prometheus特点 bootstrap 相机 Open WebUI 主板 电源 网卡 矩阵 线性代数 电商平台 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors 压测 ECS 抗锯齿 域名服务 DHCP 符号链接 配置 VMware安装mocOS macOS系统安装 xpath定位元素 自动化测试 性能测试 源码 混合开发 JDK easyui langchain 树莓派 VNC firewall ros sentinel 考研 在线office 基础入门 ceph hive Hive环境搭建 hive3环境 Hive远程模式 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 DOIT 四博智联 webgl 防火墙 NAT转发 NAT Server Unity Dedicated Server Host Client 无头主机 RAGFlow stm32项目 netty centos-root /dev/mapper yum clean all df -h / du -sh 深度求索 私域 实习 常用命令 文本命令 目录命令 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 thingsboard 状态管理的 UDP 服务器 Arduino RTOS 端口测试 epoll 腾讯云大模型知识引擎 政务 分布式系统 监控运维 Prometheus Grafana 技术共享 dell服务器 iventoy VmWare OpenEuler css3 MySql 虚拟局域网 frp 磁盘监控 加解密 Yakit yaklang 邮件APP 免费软件 金仓数据库 2025 征文 数据库平替用金仓 显卡驱动 eclipse Ubuntu Server Ubuntu 22.04.5 服务器配置 生物信息学 执法记录仪 智能安全帽 smarteye tcpdump 移动魔百盒 SysBench 基准测试 流量运营 USB转串口 Jellyfin 飞牛NAS 飞牛OS MacBook Pro harmonyOS面试题 我的世界 我的世界联机 数码 金融 网络用户购物行为分析可视化平台 大数据毕业设计 昇腾 npu Invalid Host allowedHosts 我的世界服务器搭建 Wi-Fi 超融合 WebUI DeepSeek V3 llama.cpp 链表 jetty undertow deepseek r1 Dell HPE 联想 浪潮 云电竞 云电脑 todesk 带外管理 硬件 设备 PCI-Express Python基础 Python教程 Python技巧 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 iphone .net mvc断点续传 P2P HDLC iftop 网络流量监控 log4j QT 5.12.12 QT开发环境 Ubuntu18.04 make命令 makefile文件 Erlang OTP gen_server 热代码交换 事务语义 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 状态模式 freebsd Xinference RAID RAID技术 磁盘 存储 环境配置 uv dns是什么 如何设置电脑dns dns应该如何设置 Claude 安卓 AnythingLLM AnythingLLM安装 镜像 AI作画 navicat QQ 聊天室 rclone AList webdav fnOS 工业4.0 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm ROS IM即时通讯 剪切板对通 HTML FORMAT 多进程 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK wps 测试用例 hexo rnn matplotlib 个人博客 小智AI服务端 xiaozhi TTS MacOS录屏软件 IMX317 MIPI H265 VCU 银河麒麟服务器操作系统 系统激活 can 线程池 算力 微信开放平台 微信公众号配置 linux安装配置 Radius 游戏开发 Playwright 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 Cookie edge浏览器 RAG 检索增强生成 文档解析 大模型垂直应用 物联网开发 社交电子 USB网络共享 minecraft ssh漏洞 ssh9.9p2 CVE-2025-23419 分布式训练 ip命令 新增网卡 新增IP 启动网卡 rime 系统开发 binder 车载系统 framework 源码环境 嵌入式Linux IPC gnu PX4 kali 共享文件夹 离线部署dify 信创 信创终端 中科方德 DBeaver 数据仓库 kerberos 程序员创富 nlp Windsurf ABAP perf openstack Xen EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 TCP协议 eNSP 企业网络规划 华为eNSP 网络规划 存储维护 NetApp存储 EMC存储 灵办AI 聚类 docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 开发 ai小智 语音助手 ai小智配网 ai小智教程 esp32语音助手 diy语音助手 milvus 数据库系统 C# MQTTS 双向认证 emqx trea idea rpa 做raid 装系统 trae 自动化任务管理 ubuntu24.04.1 火绒安全 内网服务器 内网代理 内网通信 YOLOv12 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 西门子PLC 通讯 fast 大模型应用 vr 键盘 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 代理服务器 影刀 #影刀RPA# 嵌入式系统开发 风扇控制软件 IO VSCode Linux的权限 MacMini 迷你主机 mini Apple spark HistoryServer Spark YARN jobhistory 项目部署 李心怡 wpf conda配置 conda镜像源 raid5数据恢复 磁盘阵列数据恢复 docker部署Python AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 figma 远程服务 ai工具 java-rocketmq 语法 Google pay Apple pay GIS 遥感 WebGIS 大模型部署 minicom 串口调试工具 Kylin-Server 内网环境 热榜 CentOS seleium 目标跟踪 OpenVINO 推理应用 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR WebRTC win服务器架设 windows server xshell termius iterm2 docker run 数据卷挂载 交互模式 VMware创建虚拟机 neo4j 数据库开发 database 虚幻引擎 搭建个人相关服务器 DocFlow 本地知识库部署 DeepSeek R1 模型 ubuntu24 vivado24 产品经理 SRS 流媒体 直播 ArcTS 登录 ArcUI GridItem MDK 嵌入式开发工具 论文笔记 sublime text arkUI 服务网格 istio arcgis js 运维监控 linux环境变量 自动化编程 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 bot Docker leetcode 推荐算法 蓝桥杯 软负载 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 CLion 服务器部署ai模型 鸿蒙开发 移动开发 swoole curl wget hosts risc-v AI Agent 字节智能运维 xml Deepseek-R1 私有化部署 推理模型 欧标 OCPP visual studio searxng lua 网络药理学 生信 PPI String Cytoscape CytoHubba vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 cmos triton 模型分析 音乐库 飞牛 实用教程 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 宕机切换 服务器宕机 regedit 开机启动 deep learning 京东云 Ubuntu共享文件夹 共享目录 Linux共享文件夹 飞牛nas fnos midjourney 本地化部署 玩机技巧 软件分享 软件图标 PVE 私有化 dock 加速 干货分享 黑客工具 密码爆破 mq Unity插件 x64 SIGSEGV xmm0 匿名管道 LInux TrueLicense gpt-3 文心一言 mybatis UDP CentOS Stream docker命令大全 DNS 人工智能生成内容 服务器时间 拓扑图 网络爬虫 大模型推理 大模型学习 音乐服务器 Navidrome 音流 IO模型 ping++ 粘包问题 剧本 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 VLAN 企业网络 大模型面经 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 Redis Desktop VS Code 基础环境 ubuntu20.04 开机黑屏 沙盒 word OpenSSH AD 域管理 多路转接 网站搭建 serv00 grub 版本升级 扩容 阿里云ECS Attention 论文阅读