IP 混叠

IP 混叠的概念

  • IP aliasing 指的是在 同一个网络接口(网卡) 上配置多个 IP 地址。
  • 这些 IP 可以属于同一个子网,也可以属于不同子网。
  • 作用:一台设备可以同时参与多个网络,或者提供多个服务 IP。
  • U-Boot 的网络栈非常简化,只支持一个活动接口(ethact)和一个 IP 地址(ipaddr)。
  • Linux 网络栈允许在一个接口上绑定多个 IP 地址(通过 ip addr add)。
  • Windows,BSD 系列,路由器/交换机大多数支持在逻辑接口上配置多个 IP(虚拟接口、子接口)

为什么服务器可以通过 ip addr add 添加另一个 IP?

  • 原因 :Linux 支持 多 IP 地址绑定在同一个网卡(多播地址或别名) ,这叫 IP aliasing

  • 当你执行:

    Shell 复制代码
    sudo ip addr add 192.168.1.133/24 dev eth0

    你实际上给 eth0 增加了一个新的 IP 地址(192.168.1.133),并指定它属于 /24 子网(掩码 255.255.255.0)。

  • 这样,服务器同时拥有:

    • 原来的公司内网 IP(比如 10.x.x.x)
    • 新增的 192.168.1.133
  • 所以它可以同时在两个网络中通信(逻辑上是两个子网)。


计网知识点

  1. 子网(Subnet)
    • 子网掩码决定网络地址主机地址的划分。
    • /24 → 掩码 255.255.255.0 → 网络地址是前 24 位,主机地址是后 8 位。
    • 所以 192.168.1.111192.168.1.133 在同一子网,可以直接通信,无需网关。
  2. CIDR 表示法
    • /n 表示前 n 位是网络地址位。
    • /24 → 255.255.255.0
    • /25 → 255.255.255.128
  3. 网关(Gateway)
    • 当目标 IP 不在本地子网 时,需要通过网关转发。(例如如果板子IP设置为 192.168.1.111/25,则192.168.1.133与其不在同一子网,则需要网关转发)
    • 如果两台设备在同一子网,网关不参与(例如如果板子IP设置为 192.168.1.111/24,则192.168.1.133与其在同一子网,则不需要网关转发)。
  4. ARP(地址解析协议)
    • 在同一子网通信时,设备通过 ARP 获取对方的 MAC 地址。
  5. IP aliasing
    • 一个网卡可以绑定多个 IP 地址,属于不同子网或同一子网。

✅ 服务器:Linux 中设置IP混叠

现代 Linux 推荐使用 ip 命令:

c 复制代码
# 添加 IP 地址
sudo ip addr add 192.168.1.133/24 dev eth0  
# 删除 IP 地址
sudo ip addr del 192.168.1.133/24 dev eth0  
# 查看 IP 地址
ip addr show dev eth0
# 查看Linux系统的路由表 ,路由表决定了当系统要发送一个 IP 数据包时,应该通过哪个接口、走哪条路径。
ip route
# 查看ARP表(存储 IP → MAC 映射)
arp -n

✅ 板子:U-Boot 中设置IP地址

  • ipaddr:本机 IP 地址。
  • netmask:子网掩码。
  • gatewayip:默认网关 IP,用于跨网段通信。
  • serverip:TFTP 或其他服务的服务器 IP。
  • ethadd:eth0 的MAC地址
  • eth1add:eth1的MAC地址

设置命令:

shell 复制代码
u-boot=> setenv ipaddr 192.168.1.111 
u-boot=> setenv netmask 255.255.255.0  #子网掩码,用于子网划分,1-255属于同一子网,不非该子网IP通信则需要走 gatewayip
u-boot=> setenv serverip 192.168.1.133   # 服务器ip
u-boot=> setenv gatewayip 192.168.1.1    # dhcp命令会自动获取,自己设置时没啥用
u-boot=> saveenv

结论

  • 只要配置服务器增加一个混叠IP,让板子与服务器的混叠IP连接到同一交换机,后设置板子与服务器ip处于同一子网,板子就可以在uboot中通过tftp 0xD0000000 zephyr.bin;来从服务器获取文件了。
  • 问题:板子:192.168.1.111,服务器:192.168.1.133 不能相互ping通。
    • 现象:就是在 U-Boot 中 ping 192.168.1.133是通的,在服务器 ping 192.168.1.111不通。(只要在U-boot中执行个tftp 0xD0000000 111111.bin命令让Uboot网络处于活跃状态,就通了)
    • 原因:U-Boot 空闲时不响应 ARP 请求 ,Linux ping 时无法解析 MAC → ping 超时。一旦 U-Boot 进入网络命令(tftppingdhcp),它就会处理 ARP → Linux ping 成功。
相关推荐
SoleMotive.2 小时前
sse和websocket的区别
网络·websocket·网络协议
ZeroNews内网穿透2 小时前
RStudio Server 结合 ZeroNews,实现远程访问管理
运维·服务器·网络·数据库·网络协议·安全·web安全
北方的流星2 小时前
华为访问控制列表的配置
运维·网络·华为
我叫安查查2 小时前
在Ubuntu系统上使用docker部署GPUStack教程【亲测成功】
linux·ubuntu·docker·gpustack
脑壳疼___2 小时前
ubuntu安装postgresql、postgis、pgrouting
linux·ubuntu·postgresql
rockingdingo2 小时前
利用 OneKey MCP Router Python SDK构建多领域大模型Function Call多工具调用数据集
网络·windows·python·ai agent·mcp
我送炭你添花2 小时前
Pelco KBD300A 模拟器:01.Pelco 协议前世今生 & KBD300A 键盘基础解析
网络·python·计算机外设·pyqt
达子6662 小时前
git-lfs的安装配置,解决大文件存储问题
linux·c++·git
测试人社区—小叶子2 小时前
使用开源模型微调,构建专属的测试用例生成机器人
运维·网络·c++·人工智能·机器人·自动化·测试用例