You need to enable JavaScript to run this app.
最新活动
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

DPDK分发应用和rte_prefetch_non_temporal()方法

DPDK是一个高性能的数据包处理框架,其中distributor应用可以帮助将数据包平均地分配给多个worker线程,以实现更高的处理速度。然而,在高速数据包处理的情况下,数据的前置加载成为瓶颈。为了提高数据加载性能,DPDK提供了rte_prefetch_non_temporal()方法。

rte_prefetch_non_temporal()方法用于将数据加载到缓存中,以便更快地访问。该方法是通过减少缓存的填充,将数据加载到缓存的“非临时”区域。以下是使用rte_prefetch_non_temporal()方法的DPDK distributor应用的示例代码:

#include <rte_prefetch.h>
#include <rte_distributor.h>

#define NUM_WORKERS 4

int main(int argc, char** argv) {
    struct rte_mempool* pktmbuf_pool = rte_pktmbuf_pool_create("MBUF_POOL", NUM_MBUFS,
        MBUF_CACHE_SIZE, 0, RTE_MBUF_DEFAULT_BUF_SIZE, rte_socket_id());
    struct rte_distributor* dist = rte_distributor_create("PKT_DIST", rte_socket_id(),
        NUM_WORKERS, RTE_DIST_ALG_BURST);
    struct worker_args w[NUM_WORKERS];

    for (int i = 0; i < NUM_WORKERS; i++) {
        w[i].dist = dist;
        w[i].worker_id = i;
    }

    while (1) {
        struct rte_mbuf* pkts_burst[MAX_PKT_BURST];
        int nb_rx = rte_eth_rx_burst(0, 0, pkts_burst, MAX_PKT_BURST);
        if (nb_rx == 0) {
            continue;
        }

        for (int i = 0; i < nb_rx; i++) {
            rte_prefetch_non_temporal(pkts_burst[i]->buf_addr);
        }

        rte_distributor_process(dist, pkts_burst, nb_rx);

        for (int i = 0; i < NUM_WORKERS; i++) {
            rte_eal_mp_wait_lcore();
        }
    }

    rte_distributor_free(dist);
    rte_mempool_free(pktmbuf_pool);
    return 0;
}

在这个示例中,rte_prefetch_non_temporal()方法被用于预先加载数据包,让数据包在到达worker线程之前尽可能在缓存中。

本文内容通过AI工具匹配关键字智能整合而成,仅供参考,火山引擎不对内容的真实、准确或完整作任何形式的承诺。如有任何问题或意见,您可以通过联系service@volcengine.com进行反馈,火山引擎收到您的反馈后将及时答复和处理。
展开更多
面向开发者的云福利中心,ECS 60元/年,域名1元起,助力开发者快速在云上构建可靠应用

社区干货

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

DPDK分发应用和rte_prefetch_non_temporal()方法 -优选内容

三代实例网络性能测试
本文以三代实例使用Pktgen-DPDK、Kernel Pktgen、iPerf3、ping工具测试网络性能的方法为例,向您介绍如何测试实例的网络PPS、网络带宽和网络时延。 注意事项本文的测试结果仅作为参考,不代表云服务器的真实最优性能... /Pktgen-DPDK/app/pktgen.c +341命令,打开pktgen.c文件并跳到341行。 按i,进入编辑模式。 在cnt -= ret;的下一行增加如下代码。if (cnt != 0) { rte_delay_us(8);}修改后的代码如下图所示。 按Esc退出编辑模式,...

DPDK分发应用和rte_prefetch_non_temporal()方法 -相关内容

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

产品体验

体验中心

云服务器特惠

云服务器
云服务器ECS新人特惠
立即抢购

白皮书

一图详解大模型
浓缩大模型架构,厘清生产和应用链路关系
立即获取

最新活动

爆款1核2G共享型服务器

首年60元,每月仅需5元,限量秒杀
立即抢购

火山引擎增长体验专区

丰富能力激励企业快速增长
查看详情

数据智能VeDI

易用的高性能大数据产品家族
了解详情

一键开启云上增长新空间

立即咨询