在DPDK 20.11中,您可以使用以下代码将接收到的报文轮询分配到4个接收队列中:
// 初始化 RSS 配置结构体
struct rte_eth_rss_conf rss_conf;
memset(&rss_conf, 0, sizeof(rss_conf));
rss_conf.rss_key = NULL;
rss_conf.rss_hf = ETH_RSS_IP | ETH_RSS_UDP; // 哈希字段包括 IP 和 UDP
// 配置每个接收队列的哈希函数
for (int i = 0; i < nb_rx_queues; i++) {
    struct rte_eth_dev_info dev_info;
    rte_eth_dev_info_get(port_id, &dev_info);
    uint16_t queue_id = rx_queue_ids[i];
    uint8_t rss_queue_id = i % dev_info.nb_rx_queues;
    // 设置 RSS 处理器和哈希值,将数据包发送到指定的接收队列
    if (rte_eth_dev_rss_hash_update(port_id, &rss_conf) != 0) {
        printf("Failed to update RSS hash configuration\n");
        return -1;
    }
    
    if (rte_eth_dev_rss_reta_update(port_id, reta_conf, dev_info.reta_size) != 0) {
        printf("Failed to update RSS redirection table\n");
        return -1;
    }
    // 将该接收队列与指定的哈希处理器进行绑定,以便从该处理器获取数据包
    if (rte_eth_dev_rx_queue_setup(port_id, queue_id, nb_rx_desc,
                                    rte_eth_dev_socket_id(port_id),
                                    NULL,
                                    rx_pktmbuf_pool) < 0) {
        printf("Failed to setup RX queue %d\n", queue_id);
        return -1;
    }
    
    rte_eth_dev_rx_queue_intr_enable(port_id, queue_id); // 启用中断
}
在上面的代码中,rss_conf.rss_hf字段指定要使用哪些哈希字段。这里我们选择了IP和UDP字段,因为它们通常是网络负载均衡的最常用字段。
然后,在每个接收队列的循环中,我们使用 rte_eth_dev_rss_hash_update() 和 rte_eth_dev_rss_reta_update() 函数来配置 RSS 哈希处理器和重定向表。通过这些函数,我们可以将数据包发送到指定的接收队列,并确保从指定的哈希处理器获取数据包。
最后,在调用 rte_eth_dev_rx_queue_setup() 函数设置接收队列时,我们还需要启用中断以便能够及时地处理到达该队列的报文。


 
                             
         
        
 
        ![异常服务器收到的包如下0:38.316208 IP (tos 0x0, ttl 112, id 0, offset 0, flags [DF], proto IPIP (4), length 72)
    172.22.132.131 > 10.26.211.160: IP (tos 0x0, ttl 118, id 12337, offset 0, flags [DF], proto TCP (6), length 52)
    121.35.103.108.5816 > 172.2...](https://linuxcpp.0voice.com/zb_users/upload/2023/05/202305162224299866311.png) 
         
         
         
         
         
         
        
 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                