光有高级可编程中断控制器的硬件支持还不够,Linux 内核还必须能利用到这些硬件特质,所以只有 kernel 2.4 以后的版本才支持把不同的硬件中断请求(IRQs)分配到特定的 CPU 上,这个绑定技术被称为...更多介绍请参看 Linux 内核源代码自带的文档:linux-2.6.31.8/Documentation/IRQ-affinity.txt 如何使用 先看看系统上的中断是怎么分配在 CPU 上的,很显然...IRQ 到不同 CPU,否则自己手动绑定做的更改将会被自动调节进程给覆盖掉。...如果想修改 IRQ 90 的中断处理,绑定到第2个 CPU(CPU1): # /etc/init.d/irqbalance stop # echo "2" > /proc/irq/90/smp_affinity...CPU 上将会减轻某个 CPU 的负担,提高多个 CPU 整体处理中断的能力; 对于数据库服务器这样的应用来说,把磁盘控制器绑到一个 CPU、把网卡绑定到另一个 CPU 将会提高数据库的响应时间、优化性能
网卡中断 获取网卡设备所有中断 [root@PowerCycle_1_DL380G7 ~]# cat /proc/interrupts|grep -iw eth0 52: 12403...numa_node for pci device) [root@PowerCycle_1_DL380G7 ~]# cat /sys/class/net/eth0/device/numa_node 0 依次绑定网卡中断到同...node 的cpu core,若网卡中断数大于node core数,则重新从第一core开始,循环绑定所有中断 (附录:IRQ-affinity) echo 0 > /proc/irq/52/smp_affinity_list...# 将中断52绑定到core 0 注意事项 默认情况下,有一个irqbalance服务对IRQ进行负载均衡,在设置中断绑定时,可以根据需要停止这个服务。...CPU2 CPU3 CPU4 CPU5 CPU6 CPU7 CPU8 CPU9 CPU10
其实,在机器启动的时候,系统就已经识别了所有设备,并且也把相应的中断处理器加载到中断表中。 下面是请求CPU关注的两种方式: 基于中断 基于轮询 所有的linux操作系统都是基于中断驱动的。.../proc/interrupts 文件 在linux的机器上,/proc/interrupts这个文件包含有关于哪些中断正在使用和每个处理器各被中断了多少次的信息。...硬中断主要分为两种类别: 非屏蔽中断(Non-maskable interrupts,即NMI):就像这种中断类型的字面意思一样,这种中断是不可能被CPU忽略或取消的。...为了解决中断处理程序执行过长和中断丢失的问题,Linux 将中断处理过程分成了两个阶段,也就是上半部和下半部: 上半部用来快速处理中断,它在中断禁止模式下运行,主要处理跟硬件紧密相关的或时间敏感的工作。...不过要注意的是,软中断不只包括了刚刚所讲的硬件设备中断处理程序的下半部,一些内核自定义的事件也属于软中断,比如内核调度和 RCU 锁(Read-Copy Update 的缩写,RCU 是 Linux 内核中最常用的锁之一
把某个进程/线程绑定到特定的cpu核上后,该进程就会一直在此核上运行,不会再被操作系统调度到其他核上。但绑定的这个核上还是可能会被调度运行其他应用程序的。...操作系统对多核cpu的调度 目前windows和linux都支持对多核cpu进行调度管理。 软件开发在多核环境下的核心是多线程开发。...CPU 的一个核心被复制到另外一个核心,这会造成额外的开销 绑定进程到cpu核上运行 查看cpu有几个核 使用cat /proc/cpuinfo查看cpu信息,如下两个信息: processor,指明第几个...至此,就把应用程序绑定到了cpu1上运行,查看如下: -> % taskset -p 2726 pid 2726's current affinity mask: 2 启动程序时绑定cpu #启动时绑定到第二个...系统调用 sched_setaffinity可以将某个进程绑定到一个特定的CPU。
所谓cpu绑定,其实就是对进程或线程设置相应的cpu亲和力(affinity),确保进程或线程只会在设置了相应标志位的cpu上运行,进而提高应用对cpu的使用效率。...所以,如果使用cpu绑定技术,在一定程度上会避免上述问题,提升系统性能,类似技术还有gpu绑定、mic绑定等等。...– Phil Karlton 1 安装taskset $ yum install util-linux 如果系统没有taskset命令,使用yum安装util-linux即可,这是一个工具集,其中包含了...除了通过taskset命令绑定应用到指定的cpu上,也可以通过taskset命令启动应用,并指定应用运行的cpu,例如: $ taskset 0x1 sleep 10000 & [2] 14925 $...另外,除了通过taskset命令实现cpu绑定,很多语言都提供了相应的api实现cpu绑定功能,例如c的sched_setaffinity和sched_getaffinity,python 3的os.sched_setaffinity
既然我们的操作系统还有CPU特性都采用了NUMA架构,那么我们完全可以通过调整KVM对应的NUMA关系来达到KVM CPU这方面的优化。这里,我们一般是通过CPU绑定的方法来做相关操作的。...我们可以看到目前这个虚拟机0-23的CPU它都能调度使用 那么以上就是查看虚拟机CPU NUMA调度的信息,如果我们要把虚拟机绑定到固定的CPU上,我们就要做以下操作: # virsh emulatorpin...Win7-ent 18-23 –live 通过这个命令,我们把这个win7的虚拟机vCPU绑定在了18-23这6个CPU之间的核上。...一个虚拟机我有两个vCPU, 比如这个win7 ,它就是双核的,我想让里面的vCPU1和vCPU2分别绑定在不同的物理CPU上可以吗?怎么操作呢?...这里要注意的是,你把虚拟机用reboot重启,这个绑定配置还是生效的,但是你shutdown的话,CPU绑定的效果会失效。
Linux 在每个 CPU 上会创建一个 ksoftirqd 内核线程。 softirqs 是在 Linux 内核编译时就确定好的,例如网络收包对应的 NET_RX_SOFTIRQ 软中断。...event PIW: 0 0 Posted-interrupt wakeup event heidsoft@heidsoft-dev:~$ /research/linux...硬中断是昂贵的,因为它们不能被中断。即使有中断 合并(稍后详细描述),中断处理程序将独占一个 CPU 内核 完全地。NAPI 的设计允许驱动程序进入轮询模式而不是被 为每个需要的数据包接收硬中断。...在正常操作下,会引发初始硬中断或 IRQ,然后是 SoftIRQ 处理程序 它使用 NAPI 例程轮询卡。轮询例程有一个预算,它决定了 允许代码的 CPU 时间。.../about-linux-smp_affinity https://web.archive.org/web/20200225050436/http://blog.yufeng.info/archives
我们在讲Linux进阶命令-top有提到过这个sy的占用率应该很低才对,目前占用已经达到20%以上,前面的us部分才是进程真正干活的使用的cpu,也就是显示是100%,实际只有不到80%的cpu在干活。...,相当于什么也不做 done } # 导出函数,使其在子进程中可见 export -f cpu_eater # 启动多个死循环进程并绑定到特定的CPU核心 for i in "${CORES[@...5.绑定物理核心 # 未绑定核心的配置 4 # 使用了静态分配,但是未指定具体的cpu 4<...#通过这命令可以看到cpu使用绑定情况是hui变化的 virsh vcpuinfo xxx |grep -i "VCPU: " -A 1 |grep -v VC |grep -v "...这里的vcpu是指出虚拟机里面的cpu和物理cpu的绑定。
2 概念 2.1 软中断概念 linux的中断会打断CPU当前的工作,中断一般都设计的短小精悍。...但是也为了解决中断处理程序执行时间过长和中断丢失的问题,Linux的中断分为两个阶段: 上半部用来快速处理中断,它在中断禁止模式下运行,主要处理硬件相关和时间敏感的工作 下半部用来延迟处理上半部未完成的工作...而下半部以内核线程的方式执行,并且每个CPU都对应一个软中断内核线程,名字为 “ksoftirqd/CPU 编号”,比如说, 0 号 CPU 对应的软中断内核线程的名字就是 ksoftirqd/0。...不过要注意的是,软中断不只包括了刚刚所讲的硬件设备中断处理程序的下半部,一些内核自定义的事件也属于软中断,比如内核调度和RCU 锁(Read-Copy Update 的缩写,RCU是 Linux 内核中最常用的锁之一...正常情况下,同一种中断在不同 CPU 上的累积次数应该差不多。比如这个界面中,NET_RX 在 CPU0 和 CPU1 上的中断次数基本是同一个数量级,相差不大。
相关函数: sched_setaffinity, sched_getaffinity, CPU_CLR, CPU_ISSET, CPU_SET, CPU_ZERO - set and get a process's...CPU affinity mask #define _GNU_SOURCE #include int sched_setaffinity(pid_t pid...(pid_t pid, unsigned int cpusetsize, cpu_set_t *mask); void CPU_CLR...(int cpu, cpu_set_t *set); int CPU_ISSET(int cpu, cpu_set_t *set); void CPU_SET(int cpu..., cpu_set_t *set); void CPU_ZERO(cpu_set_t *set); CPU_ZERO(&mask); CPU_SET(cpu_id, &mask); sched_setaffinity
注:原发表在Hadoop技术论坛 相关函数: sched_setaffinity, sched_getaffinity, CPU_CLR, CPU_ISSET, CPU_SET, CPU_ZERO...- set and get a process's CPU affinity mask 大写数实际为宏,进行位操作的宏。...*mask); void CPU_CLR(int cpu, cpu_set_t *set); int CPU_ISSET(int cpu, cpu_set_t *set)...; void CPU_SET(int cpu, cpu_set_t *set); void CPU_ZERO(cpu_set_t *set); CPU_ZERO(&mask...); CPU_SET(cpu_id, &mask); sched_setaffinity(pid, sizeof(mask), &mask);
既然vmstat把中断的开销单独列出来了,就说明一个问题,中断吃起CPU来那也是丝毫不含糊。...1 软中断的诞生 CPU正常情况下都是专心处理用户的进程的,当外部的硬件或软件有消息想要通知CPU,就会通过中断请求(interrupt request,IRQ)的方式来进行。...所以现代的Linux又发明了软件中断,配合硬中断来处理网络IO。硬中断你可以理解只是个收包的,把包收取回来放到“家里”就完事,很快就能完成,这样不耽误CPU响应其它外部高优先级的中断。...让我们将他们进行一个简单的对比: 1)和系统调用开销对比 《深入理解Linux内核-第五章》开头的一句话,很形象地把中断和系统调用两个不相关的概念联系了起来,巧妙地找到了这二者之间的相似处。...大家感兴趣的,可以继续阅读《深入理解Linux内核》的-第五章。 根据前文的实验结果,进程上下文切换开销是3us-5us。
[toc] 如何设置IDT IDT 中断描述符表定义 中断描述符表简单来说说是定义了发生中断/异常时,CPU按这张表中定义的行为来处理对应的中断/异常。...中断描述符项定义 当中断发生,cpu获取到中断向量后,查找IDT中断描述符表得到相应的中断描述符,再根据中断描述符记录的信息来作权限判断,运行级别转换,最终调用相应的中断处理程序; 这里涉及到Linux...如下简述之: 我们知道CPU只认识逻辑地址,逻辑地址经分段处理转换成线性地址,线性地址经分页处理最终转换成物理地址,这样就可以从内存中读取了; 逻辑地址你可以简单认为就是CPU执行代码时从CS(代码段寄存器...pre-cpu的中断栈,还是使用IST的中断栈; type表示所中断是何种类型,目前有以下四种: enum { GATE_INTERRUPT = 0xE, //中断门 GATE_TRAP...硬件中断相关IDT的初始化也是在Linux启动时完成,在start_kernel中通过调用init_IRQ完成,我们来看一下: void __init init_IRQ(void) { int
中断处理 - 上半部(硬中断) 由于 APIC中断控制器 有点小复杂,所以本文主要通过 8259A中断控制器 来介绍Linux对中断的处理过程。...处理中断请求 当一个中断发生时,中断控制层会发送信号给CPU,CPU收到信号会中断当前的执行,转而执行中断处理过程。...这里要注意的是,如果中断处理过程能够开启中断的,那么就把中断打开(因为CPU接收到中断信号时会关闭中断)。...鉴于这个原因,Linux把中断处理分为两个部分,上半部 和 下半部,上半部 在前面已经介绍过,接下来就介绍一下 下半部 的执行。...softirq机制 中断下半部 由 softirq(软中断) 机制来实现的,在Linux内核中,有一个名为 softirq_vec 的数组,如下: static struct softirq_action
mask) - 绑定进程到CPU win32api.GetSystemInfo()[5] - 查询当前机器有几个CPU win32api.GetCurrentProcess() - 获取当前进程信息...其中绑定CPU是mask的值如下: 0x0001 1 0x0002 2 0x0003 1 or 2 0x0004 3 0x0005 1 or 3 0x0006 2 or 3 0x0007 1, 2, or...示例 import win32process import win32api # 绑定到CPU 1 win32process.SetProcessAffinityMask(win32api.GetCurrentProcess...(), 0x0001) # 绑定到CPU 2 win32process.SetProcessAffinityMask(win32api.GetCurrentProcess(), 0x0002) #...绑定到CPU 1 or 2 win32process.SetProcessAffinityMask(win32api.GetCurrentProcess(), 0x0003)
Linux系统有时需要取消挂载一些设备或者目录, Filesystem Type Size Used Avail Use% Mounted on /dev/sda3 ext4
最近在研究异步消息处理, 突然想起linux内核的中断处理, 里面由始至终都贯穿着”重要的事马上做, 不重要的事推后做”的异步处理思想....在进入中断服务程序时, CPU已经自动禁止了本CPU上的中断响应, 因为CPU不能假定中断服务程序是可重入的. 中断处理程序的第一步要做两件事情: 1....中断处理的这几个阶段中不能调用可能导致睡眠的函数(包括分配内存); 对于第一个问题, 较新的linux内核增加了ksoftirqd内核线程, 如果持续处理的softirq超过一定数量, 则结束中断处理过程...据说在montavista(一种嵌入式实时linux)中, 将内核的中断机制做了修改. (某些中断的)中断处理过程被赋予了task结构, 能够被内核调度. 解决了上述两个问题....工作队列 linux基线版本的内核在解决上述问题上, 提供了workqueue机制.
为了让CPU在固定的核心上执行,我们可以使用taskset指令,让程序绑定逻辑核心。 taskset -c 0,10 ....过了3秒后,通过两个全局变量的值表达出不同场景的处理能力: 不设置CPU绑定 ..../bind_core a:999409723 b:994174648 设置绑定到0号CPU逻辑核心 taskset -c 0 ..../bind_core a:563819215 b:564766868 设置绑定到0,1号CPU逻辑核心 taskset -c 0,1 ....而绑定的核心数超过线程数时(如绑定到0,1,2号逻辑核心),其效率并没有明显提高。当然上述结论有个前提:这是CPU资源密集型的场景。
本文首发于 GiantPandaCV :绑定cpu 本文主要内容是介绍移动端优化会涉及到的绑定cpu(cpu affinity)[2,3]的概念和相关验证实验。...master/libc/include/sched.h #ifndef _SCHED_H_ #define _SCHED_H_ #include #include <linux...// 如果要绑定所有核,则是:11111111111111111111111111111111 // 该变量每个bit位由用户根据需要绑定的cpu编号设定。...根据实验结果可以看到,对比绑定大核和小核,确实绑定大核上运行会比绑定小核运行速度要更快,不过这里大核我是显式绑定6和7,但是多数情况下会失败,绑到了4和5,不知道是不是用户自己绑定有什么限制,如果系统调度就可以跑到.../platform/bionic.git/+/master/libc/include/sched.h 5 https://linux.die.net/man/2/sched_setaffinity
常用性能监测工具 Linux系统下,CPU与内存子系统性能调优的常用性能监测工具有top、perf、numactl这3个工具。1) top工具 top工具是最常用的Linux性能监测工具之一。...2) perf工具 perf工具是非常强大的Linux性能分析工具,可以通过该工具获得进程内的调用情况、资源消耗情况并查找分析热点函数。...report 查看记录 3) numactl工具 numactl工具可用于查看当前服务器的NUMA节点配置、状态,可通过该工具将进程绑定到指定...因此在应用程序运行时要尽可能地避免跨NUMA访问内存,这可以通过设置线程的CPU亲和性来实现。常用的修改方式有如下:(1)将设备中断绑定到特定CPU核上。.../mongod (3)可以使用 taskset 命令把一个程序绑定在一个核上运行。 taskset -c 0 .
领取专属 10元无门槛券
手把手带您无忧上云