linux 硬件中断调节
什么是中断
中断interrupts是指硬件主动的来告诉CPU去做某些事情。比如网卡收到数据后可能主动的告诉CPU来处理自己接受到的数据,键盘有了按键输入后会主动告知CPU来读取输入。 硬件主动的打扰CPU这种沟通方式就叫做中断。不同的设备会有一个中断号叫IRQ号 来唯一标识自己,这样CPU就知道发生中断的是哪些设备。
中断通常都是硬件产生的一些信号,该信号会先发送给中断控制器,现在叫做通常用的是高级可编程终端控制器APIC。 该控制器会把中断信息转发给CPU。
linux 2.4版本以后能够支持把不同硬件产生的中断分配给不同的CPU CORE处理。 这种技术叫做 SMP IRQ Affinity。更多介绍请参看Linux内核源代码自带的文档:linux-2.6.31.8/Documentation/IRQ-affinity.txt。
如何查看中断
我们首先来了解两个基本命令:
- cat /proc/interrupts,查看系统上的中断情况,通常网卡的中断会被分配到CPU0上。
- cat cat /proc/cpuinfo,查看CPU信息,有多少CPU,有多少核心。
比如下面的命令输出。
cat /proc/interrupts | head
CPU0 CPU1 CPU2 CPU3 CPU4 CPU5 CPU6 CPU7 CPU8
0: 9906 0 0 0 0 0 0 0 0 IO-APIC-edge timer
1: 660 0 0 0 0 0 0 0 0 IO-APIC-edge i8042
7: 0 0 0 0 0 0 0 0 0 IO-APIC-edge parport0
8: 1 0 0 0 0 0 0 0 0 IO-APIC-edge rtc0
第一列是IRQ Number, 最后一列是硬件名称。 我们把head 命令换成grep eth 可以看见各网卡的中断情况如下
cat /proc/interrupts | grep eth
18: 19237552 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth0
19: 1570 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth1
可知,网卡eth0 IRQ number 18. 中断分配给CPU0. 网卡eth1 IRQ number19 中断也分配给CPU0.
如何调整
上面我们看见了中断的分配情况。所有网卡的中断都分配给了CPU 0 。 这样如果我们的机器有多块网卡,那么在CPU 负荷过高的时候可能就不能有效的响应每一块网卡的中断请求。 我们希望把不同网卡的中断请求发送给不同的CPU 可以像下面这样做。
echo "2" > /proc/irq/19/smp_affinity
这样把irq 19的硬件也就是eth1的中断请求发送给CPU1. 为什么这里是echo 2呢? 这是因为 cpu在系统中的表示是二进制表示如下
0000 0001 cpu0
0000 0010 cpu1
自然十进制的2就代表第二块cpu。 运行完上面的命令我们再看中断情况如下:
cat /proc/interrupts | grep eth
18: 19237980 0 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth0
19: 1792 19 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth1
cat /proc/interrupts | grep eth
18: 19237880 0 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth0
19: 1792 28 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth1
cat /proc/interrupts | grep eth
18: 19238980 0 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth0
19: 1792 48 0 0 0 0 0 0 0 0 IO-APIC-fasteoi eth1
我们运行了不同次数的命令,可以看见对于irq 19. cpu 0 上的中断数不再增加而cpu1的中断数一直增加,所以cpu1现在负责相应eth1的中断请求。
意义
在网络非常 heavy 的情况下,对于文件服务器、高流量 Web 服务器这样的应用来说,把不同的网卡 IRQ 均衡绑定到不同的 CPU 上将会减轻某个 CPU 的负担,提高多个 CPU 整体处理中断的能力。 对于数据库服务器这样的应用来说,把磁盘控制器绑到一个 CPU、把网卡绑定到另一个 CPU 将会提高数据库的响应时间、优化性能
other
还有一些其它需要知道的事情如:
interrupt affinity with multiple cores
在上面的例子中我们 echo 2 指定网卡eth1的中断请求发送给CPU 1. 但有时候可以echo 3 把网卡eth1的请求平均发送给 cpu 0和1。因为1+2 = 3 代表这两块cpu。
我们说有时候是因为 I0-APIC的工作模式有两种logic和 physical。 只有在logical的情况下才可以做到这一点。 logical模式这种CPU 自动负载均衡的机制只能支持最多8个core。所以一旦CPU过多可能无法使用logical模式。 不过这样也不是什么坏事,因为这种模式其实对性能有一定影响, 考虑下面这种情况:
一个TCP connection发来请求给eth1. 中断被cpu 0 响应。 cpu0 做如下事情:
1. 读取TCP相关数据
2. 放入高速缓存和内存
同一个TCP connection 发来另一个请求,中断被cpu 1响应。 cpu1 做如下事情:
1. 读取 缓存中的数据, 发现自己的高速缓存中没有
...
可见不同的cpu 来handle同一个网卡有时会导致性能的下降。
linux 硬件中断调节的更多相关文章
- Linux 多核下绑定硬件中断到不同 CPU(IRQ Affinity) 转
硬件中断发生频繁,是件很消耗 CPU 资源的事情,在多核 CPU 条件下如果有办法把大量硬件中断分配给不同的 CPU (core) 处理显然能很好的平衡性能.现在的服务器上动不动就是多 CPU 多核. ...
- Linux内核中断学习
1.内核中断概述 (1)在OS环境下编写中断处理函数与之前在裸机中编写中断处理函数的方式是不一样的,在Linux内核中提供了一套用来管理硬件中断资源的软件体系架构. (2)在操作系统中,中断号与gpi ...
- Linux 内核中断内幕
转自:http://www.ibm.com/developerworks/cn/linux/l-cn-linuxkernelint/index.html#resources Linux 内核中断内幕 ...
- Linux的中断 & 中断和异常的区别
参考 http://www.yesky.com/20010813/192117.shtml 结构化程序设计思想认为:程序 = 数据结构 + 算法.数据结构体现了整个系统的构架,所以数据结构通常都是代码 ...
- Smart210学习记录-------linux驱动中断
Linux中断 Linux 的中断处理分为两个半部,顶半部处理紧急的硬件操作,底半部处理不紧急的耗时操作.tasklet 和工作队列都是调度中断底半部的良好机制,tasklet 基于软中断实现.内核定 ...
- linux内核--中断处理程序
一个设备的中断处理程序是它设备驱动程序的一部分--设备驱动程序是用于对设备进行管理的内核代码.中断处理程序与其他内核函数的真正区别在于,中断处理程序是被内核调用来响应中断的,而它们运行于我们称之为中断 ...
- Linux内核中断和异常分析(中)
在linux内核中,每一个能够发出中断请求的硬件设备控制器都有一条名为IRQ的输出线.所有现在存在的IRQ线都与一个名为可编程中断控制器的硬件电路的输入引脚相连,上次讲到单片机的时候,我就讲到了单片机 ...
- linux内核中断之看门狗
一:内核中断 linux内核中的看门狗中断跟之前的裸板的中断差不多,在编写驱动之前,需要线把内核自带的watch dog模块裁剪掉,要不然会出现错误:在Device Drivers /Watchdog ...
- [转帖]Linux 硬件和系统配置查看命令小结
https://blog.csdn.net/strongwangjiawei/article/details/8208825 转帖了不少 发现自己记住的还是不多.. Linux 硬件和系统配置查看命令 ...
随机推荐
- 掌握Spark机器学习库-07-回归算法原理
1)机器学习模型理解 统计学习,神经网络 2)预测结果的衡量 代价函数(cost function).损失函数(loss function) 3)线性回归是监督学习
- 契约式设计(DbC)感想(二)
契约式设计6大原则的理解 在<Design by Contract原则与实践>中,作者定义了契约式设计的6大原则: 区分命令和查询: 将基本查询和派生查询区分开: 针对每个派生查询,设定一 ...
- HTML5——loading
https://www.cnblogs.com/wangmeijian/p/4449150.html https://www.cnblogs.com/yunser/p/canvas-baidu-loa ...
- iOS重签
由于渠道推广需要,可能需要多个包做备份推广,区别是icon.游戏名称.登录logo.bundleid.签名证书.支付Consumables不同,其他游戏包体完全相同. 反复修改多次文件提交Jenkin ...
- Objective-C 是动态语言
Objective-C 的动态性是由 runtime 相关的库赋予的. 当然其他语言也完全可以运行在一个 Runtime 库上而获得动态性,由于多数高级语言的诞生都对应着一种编译器,因此将编译器的特性 ...
- 处理不同jQuery版本的兼容性问题
众所周知,jquery版本很多,而且有些版本的冲突也非常明显,有一些网上流传的很实用的插件是用A版本写的,但是要实现另各功能又必須用B版本.所以实现版本之間的和平相处很重要. 1.这里介绍一个函数,可 ...
- day22-类的封装、property特性以及绑定方法与非绑定方法
目录 类的封装 两个层面的封装 第一个层面 第二个层面 封装的好处 私有模块 类的propertry特性 setter 和 deleter 类与对象的绑定方法与非绑定方法 类的封装 将类的属性或方法隐 ...
- TCP的链接过程
** TCP 三次握手 四次挥手** 客户端 服务器端 交互的模式 ---> 应答模式* 应答模式 ---> 客户端发起请求 服务器端回应请求** 客户端先去发起请求 ---> 查看 ...
- while(n--)
while(n--)的意思:先判断n是否等于0,如果等于0,就不循环.如果不等于0,就进入循环,同时n的值减1.一直等到n=0才退出while循环. C语言.C++
- Layui下拉选渲染
下拉选渲染有很多方式,这个比较简单,记录一下: HTML代码如下: <div class="layui-input-inline"> <input type=&q ...