Linux Wlan L3~L2封包逻辑详解

拓扑及配置

分析流程

  • PC1去ping 外网的server,发送数据包的L2地址(MAC地址)及L3地址(IP地址) 应该如何变化?

组包结果

  • PC发送封包
  • PC接收封包

抓包验证

  1. PC1 发送ping包
  2. SERVER端接收包
  3. SERVER reply 包
  4. PC接收reply包

上面我们分发送和接收简单介绍了L2和L3的封包逻辑,是按照什么依据呢?

  1. IP地址是端到端的
    源IP :电脑发出时是 192.168.10.2,经过路由器NAT后变成公网IP 10.0.0.1
    目的IP:始终不变(发送包情况)
  2. MAC地址是逐跳的
    每经过一个路由器,源、目的MAC地址完全重写,拆开外层MAC → 查路由表 → 包装新MAC → 转发

流程梳理

  1. ping触发后,如果是域名,则触发DNS --> IP地址
  2. 主机判定ip地址是否属于本机,若不属于,查询路由表确定下一跳IP
  3. 查询ARP缓存,确定吓一跳MAC
  4. 填入目的MAC,
  5. 接口转发
我们深入代码,主要关注负责获取邻居的MAC地址并通过邻居子系统发送数据包

在这里我们就不加入路由模块参与讨论了

  1. IP层到链路层转换的关键桥梁
  2. 确定用于查找邻居缓存的目标IP地址

    rt_gw4为网关地址,192.168.10.1

  3. 查询内核的ARP哈希表

    哈希值计算

在这里,我们不讨论创建邻居项的分路:

什么是邻居子系统?

邻居子系统是Linux内核网络协议栈中的一个核心组件,它负责管理同一局域网中相邻设备之间的地址映射关系。换句话说,它的主要工作就是:把IP地址(三层)转换成MAC地址(二层)

相关推荐
姚愚谦2 分钟前
Linux源码-通用双向链表的实现
linux
麦麦麦当劳大王6 分钟前
OpenClaw安装部署(Windows/Linux/MacOS)
linux·windows·macos
KaMeidebaby8 分钟前
卡梅德生物技术快报|羊驼免疫:分子生物学实战:基于羊驼免疫的重链抗体制备与全流程验证方案
前端·网络·数据库·人工智能·算法·百度
烁3478 分钟前
shell脚本简单语法
linux·娱乐
ylscode11 分钟前
Claude Fable 5遭多智能体越狱攻击:Anthropic最强AI安全防线被击穿,12万字符系统提示泄露
网络·人工智能·安全
2401_8685347811 分钟前
系分_案例_系统架构、中间件、微服务与消息队列
网络
MartinYeung521 分钟前
[论文学习]环境注入攻击(EIA)对通用网页代理的隐私洩露威胁
网络·学习
OCR_1337162127523 分钟前
技术赋能轻量化核验:OTG技术如何重构护照识读设备应用逻辑
网络
qiuziqiqi25 分钟前
webman的消费脚本进程中http请求的选择
网络·网络协议·http
站斧小威29 分钟前
2026TikTok IP隔离浏览器怎么安装:自定义IP区段,杜绝关联限流
网络