跌倒后努力爬起,No irq handler for vector (irq -1)

        内核报错:No irq handler for vector (irq -1), 在项目中偶然遇到过几次,有几次被自己迷迷糊糊的通过网上的方法给解决了。最近一次出现给我带来惨烈痛:解决问题时把客户的服务器系统搞挂了,最终问题被客户工程师先于我解决,然后领导开始质疑我的能力。痛定思痛,特此把问题总结分析一下。

问题现象:在shell和messages日志中,都不断出现下面的报错:

Dec 25 04:19:03 localhost kernel: do_IRQ: 13.98 No irq handler for vector (irq -1)
Dec 25 04:19:05 localhost kernel: do_IRQ: 13.98 No irq handler for vector (irq -1)
Dec 25 04:19:07 localhost kernel: do_IRQ: 13.98 No irq handler for vector (irq -1)
Dec 25 04:19:09 localhost kernel: do_IRQ: 13.98 No irq handler for vector (irq -1)

日志解析:cpu 13 收到了一个irq为-1,中断向量为98的中断,但没有handler。 irq竟然为-1,也就是cpu 1 上的vector_irq[98]为-1。

红帽的工程师已经确定这是因为硬件问题, Intel 5520和5500不能正确处理中断的重定向导致,问题详细情况https://support.citrix.com/article/CTX136517

解决方法:

临时解决方法是(选择其一即可):

  1. 禁用Interrupt remapping:修改grub配置中的内核引导参数,增加“ intremap=off”,然后重启系统。(也有建议添加 iommu=no-intremap或者pci=nomsi,noaer) grub配置文件,centos系统在/boot/grub/grub.conf.
  2. 禁用irqbalance,对于redhat系统可以执行以下操作:
    1. chkconfig irqbalance off
    2. service irqbalance stop
  3. Redhat建议更新BIOS。在BOIS中关闭

关于问题的详细讨论,可以参考https://bugzilla.mozilla.org/show_bug.cgi?id=831054

转载于:https://my.oschina.net/u/2854094/blog/815878

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值