最新资讯

  • 网络运输层之(3)GRE协议

网络运输层之(3)GRE协议

2025-05-07 07:00:53 0 阅读

网络运输层之(3)GRE协议


Author: Once Day Date: 2024年4月8日

一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦…

漫漫长路,有人对你微笑过嘛…

全系列文档可参考专栏:通信网络技术_Once-Day的博客-CSDN博客。


前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。人工智能学习网站 - 点击跳转。


参考文章:

  • 什么是 GRE 隧道?| GRE 协议如何工作 | Cloudflare (cloudflare-cn.com)
  • GRE技术介绍-新华三集团-H3C
  • 浅析GRE协议(通用路由封装协议)_gre协商过程-CSDN博客
  • 什么是通用路由封装(GRE)? - 华为 (huawei.com)
  • 通用路由封装协议GRE 是什么? - 知乎 (zhihu.com)
  • 通用路由封装协议GRE - 杨灏 - 博客园 (cnblogs.com)
  • GRE VPN 技术原理笔记分享-云社区-华为云 (huaweicloud.com)
  • 通用路由封装 - 维基百科,自由的百科全书 (wikipedia.org)
  • GRE Keepalive如何工作 - Cisco
  • 解决 GRE 和 IPsec 中的 IPv4 分段、MTU、MSS 和 PMTUD 问题 - Cisco
  • 了解GRE隧道Keepalive - Cisco
  • 配置 GRETAP 隧道来通过 IPv4 传输以太网帧 Red Hat Enterprise Linux 8 | Red Hat Customer
    Portal
  • 虚拟网络gretap创建实例与流程分析-CSDN博客
  • Linux下ip link创建gre隧道,为什么会连带创建gretap0和gre0 ? - 知乎 (zhihu.com)

文章目录

  • 网络运输层之(3)GRE协议
        • 1. 概述
          • 1.1 GRE协议介绍
          • 1.2 GRE使用场景
          • 1.3 GRE和VPN/IPsec/L2TP/PPTP之间的关系
          • 1.4 GRETAP介绍
          • 1.5 相关RFC文档
        • 2. 报文格式
          • 2.1 GRE报文格式
          • 2.2 旧GRE报文格式(RFC1701)区别
          • 2.3 GRE隧道对MTU和MSS的影响
        • 3. 工作流程
          • 3.1 报文封装和解封装流程
          • 3.2 GRE隧道keepalive检测
        • 4. Linux Ubuntu配置GRE接口
          • 4.1 Linux内核支持GRE选项配置
          • 4.2 Linux上配置GRE接口
        • 5. 总结

1. 概述
1.1 GRE协议介绍

GRE通用路由封装协议(Generic Rrouting Encapsulation)是一种网络协议,主要用于封装不同网络协议的数据包。

  • 这种技术允许数据包在一个异种网络中被传输,即使这些网络原生不支持正在传输的数据包协议。
  • GRE支持对组播报文的封装,这是一些其他隧道技术(如IPsec)无法做到的。
  • GRE可以运行动态路由协议,允许异地设备之间动态地交换路由信息,这对于维护大规模分布式网络的连通性至关重要。
  • GRE本身不提供加密或其他安全保护,因而通常不会单独使用于需要高安全性的环境。

例如,如果一个企业需要在使用不同版本互联网协议(如IPv6与IPv4)的两个局域网(LAN)之间建立连接,而连接这两个网的中间网络仅支持IPv4,那么GRE可以将IPv6的数据包封装在IPv4数据包中进行传输。这样,IPv6的数据包就可以“搭乘”IPv4网络,绕过协议不兼容的问题。

GRE协议的优缺点如下表所示:

优点缺点
基于IP协议,可以在互联网上使用隧道模式下封装开销较大,影响效率
支持点对点和点对多点通信不支持组播和广播(GRE支持组播)
支持多种承载网络,包括IP、MPLS等配置较为复杂,对网络管理要求较高
采用隧道技术,能够穿越NAT和防火墙缺乏流量控制和拥塞控制机制
路由可扩展性好,支持动态路由协议隧道集中终结易形成单点故障和性能瓶颈
1.2 GRE使用场景

GRE 协议有三种主要的应用场景。

(1)多协议本地网络通过单一协议骨干网实现互联。

  • 需求:不同协议的本地网络(如 IP、IPX、AppleTalk 等)需要通过单一协议(通常是 IP)的骨干网进行互联。
  • 解决方案:在本地网络的边界路由器上启用 GRE,将不同协议的数据帧封装在 GRE 隧道内,通过骨干网传输。在另一端的边界路由器上解封装,恢复原始的数据帧并转发到目标网络。这样就实现了不同协议网络之间的透明互联。

(2)扩大步数受限网络(如 RIP)的范围。

  • 需求:由于路由协议(如 RIP)的步数限制,导致网络规模受到限制,无法实现大规模网络的互联。
  • 解决方案:在需要互联的网络之间建立 GRE 隧道,将 RIP 路由更新报文封装在 GRE 隧道内传输。由于 GRE 隧道本身不增加路由步数,因此可以突破原有的步数限制,实现大规模网络的互联。同时,通过在隧道上配置静态路由或动态路由协议,可以实现隧道两端网络的路由学习和转发。

(3)与 IPsec 结合使用,提供安全的 VPN 服务。

  • 需求:远程接入用户或分支机构需要通过公共网络(如互联网)安全地接入总部网络,并保护数据的机密性和完整性。
  • 解决方案:在远程接入设备(如 PC、路由器)和总部网络的 VPN 网关之间建立 GRE over IPsec 隧道。首先,在隧道两端之间协商 IPsec 安全联盟(SA),对 GRE 隧道的数据进行加密和认证。然后,将需要传输的数据封装在 GRE 隧道内,再将 GRE 数据包封装在 IPsec 隧道内进行传输。这样就实现了数据在公共网络上的安全传输,防止了窃听和篡改。

GRE协议虽然传输的流量是不加密的,但可以通过结合IPSec技术,先建立GRE隧道对报文进行GRE封装,然后再建立IPSec隧道对报文进行加密,以保证报文传输的完整性和私密性。下面是一种常见的GRE使用拓扑图:

1.3 GRE和VPN/IPsec/L2TP/PPTP之间的关系

VPN是通过公共网络建立的虚拟专用通信网络的统称,用于连接远程用户、公司分支机构到公司内部网。主要有以下几种类型:

  • VPDN(Virtual Private Dial Network):通过PSTN/ISDN等拨号方式接入,主要使用L2TP、PPTP等隧道协议实现。
  • VPRN(Virtual Private Routing Network):通过IP网络构建,使用GRE或MPLS实现网络层的VPN。
  • VPWS(Virtual Private Wire Service):通过IP网络模拟传统租用线,提供点到点二层VPN。
  • VPLS(Virtual Private LAN Service):多点接入的二层VPN,在IP网上延伸局域网。

GRE、L2TP、IPsec、PPTP都是VPN常用的隧道技术,用于在公网上建立点到点的逻辑通道,它们的区别在于:

  • GRE是通用路由封装协议,用于在两个不同协议的网络间创建未加密的隧道,常与IPsec结合使用。
  • L2TP二层隧道协议,支持认证,多用于远程拨号VPN接入,比PPTP安全性更高。
  • IPsec在IP层对数据进行加密认证,确保安全性,但只能对单播不能对组播加密。
  • PPTP点到点隧道协议,是早期的VPN隧道协议,安全性相对较低。

在典型VPN组网中,GRE/IPsec常用于骨干网的隧道构建,L2TP/PPTP用于接入层用户拨号接入,通过结合使用来构建全面的VPN网络

例如,GRE和L2TP都是一种隧道协议,但侧重很不同,如下表所示:

GRE协议L2TP协议
协议类别网络协议用户接入协议
关注领域只关注网络端的隧道连通除网络连通外还涉及到用户侧的接入
报文报文结构比较简单,仅包含GRE头和隧道负载报文结构复杂,隧道模式下需要封装PPP协议,
网络模式下需要封装以太网帧
1.4 GRETAP介绍

GRETAP (Generic Routing Encapsulation Transparent Aggregation Protocol) 是一种网络协议,用于在以太网链路上透明地聚合和转发数据包。

GRETAP则是GRE的一种变体,专门用于封装以太网帧,主要特点和应用如下:

  1. 基于GRE (Generic Routing Encapsulation) 隧道技术,可以在两个以太网交换机之间建立点对点的隧道连接。

  2. 通过GRETAP隧道,可以将一个以太网网段扩展到另一个物理位置,实现二层网络的扩展和互联。

  3. 支持多种上层协议,如IP、IPX、AppleTalk等,具有很好的兼容性。

  4. 提供数据封装和解封装功能,在隧道入口将以太网帧封装在GRE报文中,在隧道出口解封装并还原原始帧。

  5. 采用类似于VLAN的标签(Tunnel ID)来标识不同的GRETAP隧道,支持多条隧道并行传输。

  6. 主要应用场景包括:连接物理位置分散的局域网、实现数据中心或企业网络二层互联、构建overlay网络等。

  7. 与VXLAN、NVGRE等其他隧道协议相比,GRETAP的优势是配置简单、兼容性好,但缺点是隧道数量受限,扩展性不如VXLAN等协议。

GRETAP在某些特定场合下为以太网扩展和互联提供了一种灵活的解决方案,不过随着大二层技术的发展,越来越多的场景开始采用VXLAN等新型隧道协议

1.5 相关RFC文档

下面是与GRE协议相关的主要RFC文档列表:

  1. RFC 1701 - Generic Routing Encapsulation (GRE),定义GRE的基本封装格式和协议字段。
  2. RFC 1702 - Generic Routing Encapsulation over IPv4 networks,描述如何在IPv4网络上应用GRE封装进行数据传输。
  3. RFC 2784 - Generic Routing Encapsulation (GRE),对GRE进行了扩展和修订,成为新的GRE协议标准规范。
  4. RFC 2890 - Key and Sequence Number Extensions to GRE,定义GRE的序号和密钥扩展,用于实现更可靠和安全的GRE隧道传输。
  5. RFC 7676 - IPv6 Support for Generic Routing Encapsulation (GRE),将GRE扩展到IPv6,定义在IPv6网络上应用GRE的封装格式和传输方式。
  6. RFC 8086 - GRE-in-UDP Encapsulation,指定将GRE封装在UDP内的方法,解决一些网络对GRE报文的过滤和阻塞问题。
2. 报文格式
2.1 GRE报文格式

GRE报文格式(RFC 2784)如下图所示:

GRE报文分为三个组成部分,每层对应一个协议概念,如下所示:

  • 传输协议头部(Transport Protocol或者Delivery Protocol),即隧道外部协议,通常是IP报文头部。

  • 封装协议头部(Encapsulation Protocol),这里就是GRE报文头部,也称为运载协议(Carrier Protocol)

  • 净荷(载荷,Payload Packet),封装前的报文称为净荷,封装前的报文协议称为乘客协议(Passenger Protocol)。

GRE头部字段解释如下:

字段长度描述
C1 bit校验和验证。
如果该位为1,表示GRE头插入了校验和(Checksum)字段。
如果该位为0,表示GRE头不包含校验和字段。
K1 bit关键字。
如果该位为1,表示GRE头插入了关键字(Key)字段。
如果该位为0,表示GRE头不包含关键字字段。
Recursion3 bits用来表示GRE报文被封装的层数。
完成一次GRE封装后将该字段加1,如果封装层数大于3,则丢弃该报文。
该字段的作用是防止报文被无限次的封装。
Flags5 bits预留字段。当前必须设为0。
Version3 bits版本字段,必须置为0。Version为1是使用在RFC2637的PPTP中。
Protocol Type16 bits乘客协议的协议类型,比如0x0800表示IPv4,0x86DD表示IPv6。
Checksum16 bits对GRE头及其负载的校验和字段。
Key31 bits关键字字段,隧道接收端用于对收到的报文进行验证。
2.2 旧GRE报文格式(RFC1701)区别

RFC2784移除了一些旧GRE协议的字段,如下所示:

  • Routing Present ®位
  • Strict Source Route (S)位
  • 递归控制字段
  • 确认号字段

RFC 1701规定的GRE头部格式如下:

RFC 1701的GRE头部字段描述如下:

字段名位数描述
C (Checksum Present)1校验和标志位。
1: Checksum和Offset字段存在
0: Checksum和Offset字段不存在
R (Routing Present)1路由标志位。
1: Routing字段存在
0: Routing字段不存在
K (Key Present)1密钥标志位。
1: Key字段存在
0: Key字段不存在
S (Sequence Number Present)1序列号同步标志位。
1: Sequence Number字段存在
0: Sequence Number字段不存在
s (Strict Source Route)1严格源路由标志位。
1: 严格源路由
0: 宽松源路由
Recur (Recursion Control)3控制GRE递归封装的最大层数,0-7。通常为0。
Flags5保留,必须为0。
Ver (Version)3GRE版本,当前必须为0。
Protocol Type16封装在GRE中的协议类型,如0x0800表示IPv4。
Checksum (可选)16GRE头部及payload的校验和。
Offset (可选)16GRE头部后附加字段的偏移量。
Key (可选)32用于身份验证的密钥。
Sequence Number (可选)32序列号,用于报文重组和去重。
Routing (可选)变长源路由列表,支持严格/宽松源路由。

相比RFC 2784 ,RFC 1701的GRE提供了更多特性,如:

  • 支持源路由选择(R/S位及Routing字段)
  • 支持递归封装(Recur字段)
  • 支持认证/加密(Key字段)
  • 支持排序和去重(Sequence Number)
  • 支持校验(Checksum)

这些附加特性也增加了GRE的复杂度和开销,所以在后续的RFC 2784中简化并移除了一些不常用的特性

2.3 GRE隧道对MTU和MSS的影响

MTU和MSS都是用来限制通过网络传输的数据包最大长度的度量单位:

  • MTU测量数据包的总大小,包括报文头部(从Ether帧的负载开始计算,比如IP报文头部)。超过 MTU 值的数据包将被分成几段或分解成较小的数据包,使之适合在网络上传输。
  • MSS仅测量有效负载,比如TCP协议的负载,这个会去掉IP和TCP头部的开销。

GRE隧道协议会在数据包原有大小基础上增加几个字节,在数据包的MSS和MTU设置中必须考虑这个因素。

如果MTU设为1500 字节,MSS设为1460 字节,则增加GRE 12字节头部后将导致数据包超过MTU限值:

1460 字节 [有效负载] + 20 字节 [TCP 标头] + 20 字节 [IP 标头] + 12 字节 [GRE 标头+ IP 标头] = 1512字节

因此,数据包将被分段,减慢数据包传递,并增加算力开销,因为超出 MTU 的数据包必须分解然后重新组合。

通过减少 MSS 长度以包含 GRE 标头,可以避免这种情况。

如果将MSS设置为1448而不是1460,那么加上GRE 12字节头部后的数据包不会超过MTU 值 1500:

1448 字节 [有效负载] + 20 字节 [TCP 标头] + 20 字节 [IP 标头] + 12 字节 [GRE 标头+ IP 标头] = 1500 字节

尽管避免了分段,但结果却是有效载荷变小,这意味着需要额外的数据包来传递数据,并增加毫秒级的数据传输延迟。不过,使用 GRE 比不使用 GRE 可以使这些数据包选择更快的网络路径,进而可以弥补损失的时间。

3. 工作流程
3.1 报文封装和解封装流程

GRE报文传输流程示意图如下:

上述流程以一个Ping Request报文为例子,介绍了如何从10.10.4.0/24网络里通过Gre0和Gre1这对GRE隧道到达10.10.6.0/24网络。

  1. 主机A创建ICMP REQUEST报文,源IP为主机A的IP(10.10.4.4),目的IP为主机B的IP(10.10.6.6)。
  2. 主机A将此ICMP报文发送给网络A的网关设备(Device A)。
  3. 网关设备Device A从物理接口(Eth0)收到这个ICMP报文后,通过路由查找,发现其下一跳地址是Gre0接口(隧道接口)。
  4. 报文进入网关设备Device A的Gre0接口,开始创建GRE头部:
    • Protocol Type字段设为0x0800,表示封装的是IPv4报文
    • 其他字段如Checksum、Key、Sequence Number等根据配置添加。
    • GRE头部添加在原始的ICMP报文之前。
  5. Gre0接口给报文创建新的IP头部:
    • 源IP为Gre0接口的local IP(本端地址)。
    • 目的IP为Gre0接口的remote IP(对端地址)。
    • 协议字段设为47,表示这是一个GRE封装报文。
    • 新的IP头部添加在GRE头部之前。
  6. 网关设备Device A通过路由查找(查找6.6.6.7的下一跳地址),将此GRE over IP报文从相应的物理接口(Eth0)发送出去。
  7. GRE报文通过公网到达另一端网关设备Device B。
  8. 网关设备Device B剥离外层IP头,根据协议字段47判断这是一个GRE报文,然后送入Gre1隧道接口里解封装处理。
  9. 网关设备Device B的Gre1隧道接口会剥离报文的GRE头部,根据Protocol Type 0x0800判断内层是一个IPv4报文。
  10. 现在Device B得到了原始的ICMP REQUEST报文,它根据报文的目的IP(查找10.10.6.6的下一跳),将其转发给Host B。
  11. Host B收到ICMP REQUEST报文,并回复ICMP REPLY报文。ICMP REPLY报文将再次通过GRE隧道返回给Host A,流程与请求方向类似。

整个过程可以概括为:原始IP报文被添加上GRE头部、新的IP头部,形成GRE over IP的封装报文,通过隧道传输。隧道出口解封装,得到原始IP报文,再转发给目的主机

需要注意,Gre接口需要配置路由条目才能将流量导入到接口中,路由的下一跳地址为Gre接口的私网地址,而不是local/remote等公网地址

3.2 GRE隧道keepalive检测

通用路由封装(GRE)的Keepalive功能是一种网络协议机制,旨在确保网络连接的持续性和可靠性。在GRE隧道中,Keepalive机制通过定期发送探测消息来检测和维持隧道两端的活动状态。

  • 避免形成数据黑洞,Keepalive检测功能用于在任意时刻检测隧道链路是否处于Keepalive状态,即检测隧道对端是否可达。如果对端不可达,隧道连接就会及时关闭,避免形成数据空洞。
  • 定期探测,Keepalive检测功能开启后,GRE隧道本端会定期(例如,每次间隔5秒)向对端发送Keepalive探测报文。若对端可达,则本端会收到对端的回应报文,若对端不可达,则收不到对端的回应报文。
  • 支持单端启用,如果在隧道一端配置了Keepalive功能,无论对端是否配置Keepalive,配置的Keepalive功能在该端都生效;隧道对端收到Keepalive探测报文,无论是否配置Keepalive,都会给源端发送一个回应报文。

GRE的keepalive探测包构成如下:

  • 内层IP头:源IP为隧道目的端IP,目的IP为隧道源端IP。
  • 内层GRE头,协议类型PT字段为0。
  • 外层IP头和GRE头,封装原始的keepalive包,用于在公网上传输。

隧道对端接收到keepalive包后,会解封装,检查内层GRE头的PT字段。若为0,则识别为keepalive包,并丢弃它,同时重置keepalive计数器

4. Linux Ubuntu配置GRE接口
4.1 Linux内核支持GRE选项配置

Linux 内核支持GRE接口需要启用以下相关配置。

功能配置宏描述
GRE 隧道支持CONFIG_NET_IPGRE启用通用 GRE 隧道支持,是使用 GRE 的基础。
GRE 隧道设备支持CONFIG_NET_IPGRE_DEMUX启用此选项可以支持多个 GRE 隧道设备,每个设备可以单独配置。
GRE 广播和组播支持(可选)CONFIG_NET_IPGRE_BROADCAST启用 GRE 隧道的广播和组播支持,允许 GRE 隧道传输广播和组播数据包。
Netfilter 连接跟踪支持(可选)CONFIG_NF_CT_PROTO_GRE如果需要对 GRE 数据包进行连接跟踪和状态检查(如防火墙规则),则需要启用此选项。
GRE IPv6报文支持CONFIG_IPV6_GRE启用GRE over IPv6支持。
IP 隧道驱动程序(可选)CONFIG_NET_IPIP虽然此选项主要用于 IPIP 隧道,但某些 GRE 实现可能也依赖于它。

在 Linux 内核的 make menuconfig 配置界面中,这些选项通常位于以下位置:

Networking support  --->
  Networking options  --->
    [*] IP: GRE demultiplexer
    [*]   IP: broadcast GRE over IP
    -*- The IPv6 protocol  --->
      [*]   IPv6: GRE demultiplexer
      [*]     IPv6: broadcast GRE over IPv6

Device Drivers  --->
  [*] Network device support  --->
    <*>   IP: GRE over IP
    <*>   IPv6: GRE over IPv6
    <*>   IP: IPIP tunnel

Netfilter Configuration  --->
  [*] IP virtual reassembly in netfilter
  [M]   "conntrack" connection tracking match support
  [M]     "conntrack" connection tracking match support for GRE

在实际运行的ubuntu服务器上,可以检查/boot目录下配置文件,如下:

onceday@ubuntu1:~$ cat /boot/config-5.15.0-100-generic |grep GRE
CONFIG_NET_IPGRE_DEMUX=m
CONFIG_NET_IPGRE=m
CONFIG_NET_IPGRE_BROADCAST=y
CONFIG_IPV6_GRE=m
CONFIG_NF_CT_PROTO_GRE=y
CONFIG_OPENVSWITCH_GRE=m

在这台ubuntu设备上,可以看到相关的GRE功能Linux内核都已经支持了。

4.2 Linux上配置GRE接口

测试和验证GRE功能需要两台Linux服务器,这里使用VirtualBox的虚拟机来搭建环境(3.1节报文封装和解封装流程所示拓扑)。

(1) 在服务器ubuntu1和ubuntu2上配置物理接口enp0s9(或者其他接口)的地址,两者之间要能Ping通(内部网络或者网卡桥接)。

# ubuntu1配置6.6.6.6/24地址
onceday@ubuntu1:~$ ip link set enp0s9 up
onceday@ubuntu1:~$ ip addr add 6.6.6.6/24 dev enp0s9
# ubuntu2配置6.6.6.7/24地址
onceday@ubuntu1:~$ ip link set enp0s9 up
onceday@ubuntu2:~$ ip addr add 6.6.6.7/24 dev enp0s9
# 两者之间可以Ping通
onceday@ubuntu1:~$ ping 6.6.6.7
PING 6.6.6.7 (6.6.6.7) 56(84) bytes of data.
64 bytes from 6.6.6.7: icmp_seq=1 ttl=64 time=0.807 ms

(2) 在两个服务器上分别配置GRE虚拟子接口,local和remote就是enp0s9接口的IP地址。

  1. 创建GRE隧道接口,gre1是隧道接口名称,remote指定对端隧道IP,local指定本端隧道IP,ttl设置封装包的TTL。

    ip tunnel add gre1 mode gre remote 6.6.6.7 local 6.6.6.6 ttl 255
    
  2. 配置隧道接口的IP地址。

    ip addr add 10.10.5.1/30 dev gre1
    
  3. 启用隧道接口。

    ip link set gre1 up
    
  4. 配置路由,将相应网段的流量引导到GRE隧道上。

    ip route add 10.10.0.0/16 dev gre1
    

服务器ubuntu1配置操作输出信息如下:

onceday@ubuntu1:~$ ip tunnel add gre1 mode gre remote 6.6.6.7 local 6.6.6.6 ttl 255
onceday@ubuntu1:~$ ip addr add 10.10.5.1/30 dev gre1
onceday@ubuntu1:~$ ip link set gre1 up
onceday@ubuntu1:~$ ip route add 10.10.0.0/16 dev gre1
onceday@ubuntu1:~$ ip addr
4: enp0s9: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
    link/ether 08:00:27:93:6f:37 brd ff:ff:ff:ff:ff:ff
    inet 6.6.6.6/24 scope global enp0s9
       valid_lft forever preferred_lft forever
    inet6 fe80::a00:27ff:fe93:6f37/64 scope link 
       valid_lft forever preferred_lft forever
8: gre1@NONE: <POINTOPOINT,NOARP,UP,LOWER_UP> mtu 1476 qdisc noqueue state UNKNOWN group default qlen 1000
    link/gre 6.6.6.6 peer 6.6.6.7
    inet 10.10.5.1/30 scope global gre1
       valid_lft forever preferred_lft forever
    inet6 fe80::606:606/64 scope link 
       valid_lft forever preferred_lft forever

最终可以看到gre1接口上面有接口IP(10.10.5.1),这个IP用于流量引流的下一跳地址。

同理完成ubuntu2的配置操作:

onceday@ubuntu2:~$ ip tunnel add gre1 mode gre remote 6.6.6.6 local 6.6.6.7 ttl 255
onceday@ubuntu2:~$ ip addr add 10.10.5.2/30 dev gre1
onceday@ubuntu2:~$ ip link set gre1 up
onceday@ubuntu2:~$ ip route add 10.10.0.0/16 dev gre1
onceday@ubuntu2:~$ ip addr
3: enp0s9: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
    link/ether 08:00:27:56:7b:06 brd ff:ff:ff:ff:ff:ff
    inet 6.6.6.7/24 scope global enp0s9
       valid_lft forever preferred_lft forever
    inet6 fe80::a00:27ff:fe56:7b06/64 scope link 
       valid_lft forever preferred_lft forever
7: gre1@NONE: <POINTOPOINT,NOARP,UP,LOWER_UP> mtu 1476 qdisc noqueue state UNKNOWN group default qlen 1000
    link/gre 6.6.6.7 peer 6.6.6.6
    inet 10.10.5.2/30 scope global gre1
       valid_lft forever preferred_lft forever
    inet6 fe80::606:607/64 scope link 
       valid_lft forever preferred_lft forever

完成以上配置之后,可以尝试进行ping操作,并且用TCP抓包看看GRE隧道报文。

onceday@ubuntu1:~$ ping 10.10.5.2
PING 10.10.5.2 (10.10.5.2) 56(84) bytes of data.
64 bytes from 10.10.5.2: icmp_seq=1 ttl=64 time=0.810 ms
64 bytes from 10.10.5.2: icmp_seq=2 ttl=64 time=0.991 ms
......

下面是对enp0s9接口抓包,可以看到外层报文和内层报文交互情况:

onceday@ubuntu1:~$ sudo tcpdump -vv  -i enp0s9
tcpdump: listening on enp0s9, link-type EN10MB (Ethernet), snapshot length 262144 bytes
17:19:29.285962 IP (tos 0x0, ttl 255, id 4763, offset 0, flags [DF], proto GRE (47), length 108)
    6.6.6.6 > 6.6.6.7: GREv0, Flags [none], length 88
        IP (tos 0x0, ttl 64, id 1897, offset 0, flags [DF], proto ICMP (1), length 84)
    ubuntu1 > 10.10.5.2: ICMP echo request, id 7, seq 1, length 64
17:19:29.286757 IP (tos 0x0, ttl 255, id 10776, offset 0, flags [DF], proto GRE (47), length 108)
    6.6.6.7 > 6.6.6.6: GREv0, Flags [none], length 88
        IP (tos 0x0, ttl 64, id 65215, offset 0, flags [none], proto ICMP (1), length 84)
    10.10.5.2 > ubuntu1: ICMP echo reply, id 7, seq 1, length 64

到此,GRE隧道接口测试就完成了,操作很简单,重点是理解GRE报文的传输流程。

5. 总结

GRE协议比较简单,但是具体的报文传输流程和路由寻路就比较难以理解。对于终端,需要设置一个GRE接口,同时配置Local IP和remote IP,这两个IP用于封装GRE报文的外层IP头。

此外,GRE接口本身还需要一个接口IP,注意这个接口IP不能直接作为外部设备的下一跳(NextHop),因为这是一个三层虚接口,没有MAC等链路层地址,所有是无法作为邻居表项存在的。

在终端上,需要对应的物理接口IP完成外部路由过程,而GRE接口IP,主要用于将物理接口的入流量(即准备进行封装的报文)导入到GRE接口中。

对于出流量(即准备进行解封的报文),则不需要依赖路由导入,而是在解析IP协议时就可以分流到GRE模块中处理。所以GRE两个方向的流量路径是不一致的,这个一开始可能不好理解,建议多多手动实践来理解。







Once Day

也信美人终作土,不堪幽梦太匆匆......

如果这篇文章为您带来了帮助或启发,不妨点个赞👍和关注,再加上一个小小的收藏⭐!

(。◕‿◕。)感谢您的阅读与支持~~~

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

搜索文章

Tags

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