AF_XDP开发环境(Ubuntu24.04.3)

安装步骤

以下是安装步骤表:

组件 安装方法 关键命令/操作 主要参考来源与说明
编译工具链 APT安装 sudo apt install -y git build-essential clang llvm libelf-dev pkg-config 基础依赖。
Linux内核头文件 APT安装 sudo apt install -y linux-headers-$(uname -r) 编译eBPF程序必需。
bpftool 源码编译 详见下方"源码编译bpftool"。 在Ubuntu 24.04上,不建议 直接用apt install bpftool,可能出现版本不匹配问题。
xdp-toolslibxdp APT安装 sudo apt install -y linux-tools-common linux-tools-generic linux-cloud-tools-generic libbpf-dev xdp-tools libxdp-dev 包含xdpdump等工具和libxdp开发库。

说明 :在Ubuntu 24.04上安装 bpftool 较特殊。不建议 直接通过 apt install linux-tools-common 安装,因为可能版本不匹配。建议通过以下步骤源码编译

bash 复制代码
# 安装依赖
sudo apt update
sudo apt install -y build-essential libelf-dev binutils-dev pkg-config

# 1. 克隆 bpftool 仓库(包含子模块)
git clone --recurse-submodules https://github.com/libbpf/bpftool.git
cd bpftool/src
# 2. 编译
make
# 3. 安装到系统路径(默认是 /usr/local/bin)
sudo make install

# 应输出类似:bpftool v7.0.0
bpftool --version

环境配置

1. 检查内核配置

AF_XDP和eBPF是内核特性,安装前需确保内核已启用相关配置:

bash 复制代码
cat /boot/config-$(uname -r) | grep -E "XDP|BPF"

请确保输出中包含 CONFIG_XDP_SOCKETS=yCONFIG_BPF=y 等关键选项。

2. 生成 vmlinux.h 头文件

此文件包含了内核数据结构定义,是编写eBPF程序的常用头文件。确认内核支持BTF后(检查 /sys/kernel/btf/vmlinux 文件是否存在),使用刚安装的 bpftool 生成:

bash 复制代码
sudo bpftool btf dump file /sys/kernel/btf/vmlinux format c > vmlinux.h

之后在eBPF内核代码中只需 #include "vmlinux.h"

开发环境验证

安装完成后,可以通过一个简单的XDP程序测试环境。

  1. 编写一个测试XDP程序 (如 xdp_pass.c):

    c 复制代码
    #include <linux/bpf.h>
    #include <bpf/bpf_helpers.h>
    
    SEC("xdp")
    int xdp_pass_func(struct xdp_md *ctx) {
        return XDP_PASS;
    }
    
    char _license[] SEC("license") = "GPL";
  2. 编译eBPF程序

    bash 复制代码
    clang -O2 -target bpf -I /usr/include/x86_64-linux-gnu -c xdp_pass.c -o xdp_pass.o
  3. 使用 xdp-tools 测试
    利用 xdp-loader(来自xdp-tools)加载程序到网络接口(如 eth0),模式选择 native

    bash 复制代码
    sudo xdp-loader load -m native eth0 xdp_pass.o

    使用 xdpdump(同样来自xdp-tools)监听接口,可以观察到流量正常通过。

后续

  • 权限问题 :加载XDP程序通常需要root权限。如果需要在非特权环境下运行AF_XDP程序,需要进行额外的内核和权限配置。
  • 网卡驱动支持 :XDP的native模式性能最优,但需要网卡驱动程序的支持。你可以通过 ethtool -i <网卡名> 查看驱动,并查阅相关驱动文档确认支持情况。
相关推荐
七歌杜金房5 小时前
我终于又有了自己的 Linux 电脑
linux·debian·mac
SkyWalking中文站12 小时前
认识 Horizon UI · 5/17:3D 基础设施地图
运维·监控·自动化运维
tntxia1 天前
linux curl命令详解_curl详解
linux
扛枪的书生1 天前
Linux 网络管理器用法速查
linux
SkyWalking中文站1 天前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控
顺风尿一寸1 天前
Java Socket 内核之旅:从 SocketChannel.read() 到 tcp_recvmsg 与 epoll 的完整调用链路
linux
雪梨酱QAQ2 天前
Kubeneters HA Cluster部署
运维
江华森2 天前
Spring Cloud 微服务全栈实战:从 Eureka 到 Docker Compose 一文贯通
运维
江华森2 天前
Matplotlib 数据绘图基础入门
运维
XIAOHEZIcode2 天前
Ubuntu 终端美化全栈指南:Bash 到 Kitty 踩坑实录
linux·ubuntu·命令行