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 成功。
相关推荐
岁岁种桃花儿2 小时前
Nginx 站点垂直扩容(单机性能升级)全攻略
网络·nginx·dns
Xの哲學2 小时前
Linux SMP 实现机制深度剖析
linux·服务器·网络·算法·边缘计算
知识分享小能手3 小时前
Ubuntu入门学习教程,从入门到精通,Ubuntu 22.04的Linux网络配置(14)
linux·学习·ubuntu
皇族崛起3 小时前
【视觉多模态】- scannet 数据的 Ubuntu 百度网盘全速下载
linux·ubuntu·3d建模·dubbo
CAU界编程小白3 小时前
Linux系统编程系列之进程控制(下)
linux·进程控制
一颗青果4 小时前
公网构建全流程与参与主体深度解析
网络
RisunJan4 小时前
Linux命令-ifconfig命令(配置和显示网络接口的信息)
linux·运维·服务器
LaoWaiHang4 小时前
Linux基础知识04:pwd命令与cd命令
linux
lbb 小魔仙4 小时前
【Linux】100 天 Linux 入门:从命令行到 Shell 脚本,告别“光标恐惧”
linux·运维·服务器
小张成长计划..5 小时前
【Linux】1:基本指令
linux