DPDK 学习第一天

DPDK

环境: wsl2 Ubuntu (不建议用wsl)

编译安装

安装必要的工具

bash 复制代码
sudo apt install -y \
  build-essential \
  meson ninja-build \
  python3-pip python3-pyelftools \
  libnuma-dev \
  pciutils ethtool \
  git wget

下载安装dpdk

bash 复制代码
wget https://fast.dpdk.org/rel/dpdk-22.11.4.tar.xz
tar xf dpdk-22.11.4.tar.xz
cd dpdk-stable-22.11.4
mkdir build && cd build
meson setup ..
ninja
sudo ninja install

HugePage(大页内存)

bash 复制代码
sudo nano /etc/sysctl.conf
# 添加:
vm.nr_hugepages=1024

sudo nano /etc/fstab
# 添加:
hugetlbfs /dev/hugepages hugetlbfs defaults 0 0

重启后生效

题主用的是wsl Ubuntu, powershell 执行wsl --shutdown

  • 检查是否生效 mount | grep huge

  • mount | grep huge

Hello 程序

c 复制代码
#include <stdio.h>
#include <rte_eal.h>
#include <rte_lcore.h>

/* 每个 lcore 上执行的函数 */
static int
lcore_hello(__rte_unused void *arg)
{
    unsigned lcore_id;

    /* 获取当前执行代码的逻辑核 ID */
    lcore_id = rte_lcore_id();

    /* 打印当前核信息 */
    printf("hello from core %u\n", lcore_id);

    return 0;   /* 返回值会被 EAL 收集 */
}

/* 主函数 */
int
main(int argc, char **argv)
{
    int ret;
    unsigned lcore_id;

    /* ================================
     * 1. 初始化 EAL(核心入口)
     * ================================ */
    ret = rte_eal_init(argc, argv);
    if (ret < 0)
        rte_panic("Cannot init EAL\n");

    /*
     * rte_eal_init 做的事情:
     * - 解析命令行参数(如 -l coremask)
     * - 初始化 hugepage 内存
     * - 初始化多核环境(lcore)
     * - 初始化设备(PCI/VFIO)
     * - 建立主从线程模型
     */

    /* ================================
     * 2. 在每个 worker lcore 上启动任务
     * ================================ */
    RTE_LCORE_FOREACH_WORKER(lcore_id) {

        /*
         * 在指定 lcore 上异步执行函数
         *
         * 参数:
         *  - 函数指针(每个核执行的函数)
         *  - 参数(这里传 NULL)
         *  - 指定的 lcore ID
         */
        rte_eal_remote_launch(lcore_hello, NULL, lcore_id);
    }

    /* ================================
     * 3. 主核(main lcore)也执行同样函数
     * ================================ */
    lcore_hello(NULL);

    /* ================================
     * 4. 等待所有 worker 核执行完成
     * ================================ */
    rte_eal_mp_wait_lcore();

    /* ================================
     * 5. 释放 EAL 资源(⚠️ 建议打开)
     * ================================ */
    // rte_eal_cleanup();

    return 0;
}
  • wsl 上执行该程序有段错误,不知道具体原因,先把rte_eal_cleanup注释掉
  • 其他错误暂时忽略掉
相关推荐
pengyi8710152 小时前
静态IP代理稳定性测试核心指标,判断IP质量的关键
网络
Johnstons2 小时前
网络可观测性落地指南:从“出了问题才排查“到“实时感知全网状态“
开发语言·网络·php
路溪非溪2 小时前
wireshark抓包看ip协议
网络·tcp/ip·wireshark
小梦爱安全2 小时前
Ansible剧本1
java·网络·ansible
科技牛牛2 小时前
平台该怎么设计更低误伤的 IP 风控策略?
服务器·网络·tcp/ip
一颗青果3 小时前
如何加速TCP传输大文件
网络·网络协议·tcp/ip
heRs BART3 小时前
Ubuntu 20.04配置网络
网络·ubuntu·php
要做一个小太阳3 小时前
blockbox配置文件详解与优化
运维·网络·prometheus
DianSan_ERP3 小时前
淘宝订单接口集成中如何正确处理消费者敏感信息的安全与合规问题?
大数据·运维·网络·人工智能·安全·servlet