可以使用多少个不同的最大CPU内核来处理一个IP数据包?

例如,我们有1个cpu,8个核心.
当一个IP数据包越过Eth0-> TCP / IP->应用程序(不包括应用程序中的处理)时,可以使用多少个最大不同的cpu内核来处理一个IP数据包?

例如,它可能是3个cpu核心:

>处理硬件中断
>进程校验和计算
>处理复制内核空间 – >用户空间(其指针已发送到套接字)

这对性能非常重要,因为核之间的每次数据传输都非常昂贵.

解决方法

一般来说,您将在一个核心上处理中断,有可能在处理它时涉及的实际内核工作将在不同的核心上发生,最后将其交给运行在第三个核心上的应用程序.在某些操作系统上,您可以设置进程关联以及中断处理程序关联,以避免弹出数据.

相关文章

/** C+⬑ * 默认成员函数 原来C++类中,有6个默认成员函数: 构造函数 析构函数 拷贝...
#pragma once // 1. 设计一个不能被拷贝的类/* 解析:拷贝只会放生在两个场景中:拷贝构造函数以及赋值运...
C类型转换 C语言:显式和隐式类型转换 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译...
//异常的概念/*抛出异常后必须要捕获,否则终止程序(到最外层后会交给main管理,main的行为就是终止) try...
#pragma once /*Smart pointer 智能指针;灵巧指针 智能指针三大件//1.RAII//2.像指针一样使用//3.拷贝问...
目录<future>future模板类成员函数:promise类promise的使用例程:packaged_task模板类例程...