Нерегулярное прерывание баланса в четырехъядерном процессоре AMD Opetron

У меня была проблема с перегрузкой CPU7. Я обнаружил, что это было вызвано прерываниями eth0, как вы можете видеть ниже cat / proc / interrupts. Я использую ядро ​​2.6.35.2 и четырехъядерный процессор AMD Opteron(tm) 2354. Мне бы хотелось, чтобы это прерывание поддерживалось всеми ядрами, поэтому я попытался повторить ff > /proc/irq/16/smp_affinity, но это не так за работой. Если я установлю 1, 2, 4, 8, 16 и т. Д., Это работает для каждого ядра, но не для нескольких. У меня также есть другие серверы, где smp_affinity имеет значение "ff", и это работает, но эти машины работают на Intel.

           CPU0       CPU1       CPU2       CPU3       CPU4       CPU5       CPU6       CPU7
  0:        126          0          0          0          0          0          0          0   IO-APIC-edge      timer
  1:          0          0          0          0          0          0          0          8   IO-APIC-edge      i8042
  9:          0          0          0          0          0          0          0          0   IO-APIC-fasteoi   acpi
 10:          0          0          0          0          0          0          0          2   IO-APIC-fasteoi   ehci_hcd:usb1, ohci_hcd:usb2, ohci_hcd:usb3
 11:          0          0          0          0          0          0          0          0   IO-APIC-fasteoi   sata_svw
 14:          0          0          0          0          0          0          0         44   IO-APIC-edge      ide0
 16:     523739      38196      20957    1288960      40051      33985      99858   12142246   IO-APIC-fasteoi   eth0
 28:      33784          0          1         24          0          4       1017     199001   IO-APIC-fasteoi   megasas
NMI:          0          0          0          0          0          0          0          0   Non-maskable interrupts
LOC:   51149605   52755152   47000502   38164758   47335488   49653390   44361349   19201949   Local timer interrupts
SPU:          0          0          0          0          0          0          0          0   Spurious interrupts
PMI:          0          0          0          0          0          0          0          0   Performance monitoring interrupts
PND:          0          0          0          0          0          0          0          0   Performance pending work
RES:   29252262   26917272   17461908    9927632   26959155   24081482   15451952    5680615   Rescheduling interrupts
CAL:      86814        186        188        177       9656        176        169        176   Function call interrupts
TLB:      13134      52049      17599      15275       9937      18316      15062       9433   TLB shootdowns
ERR:          0
MIS:          0

С наилучшими пожеланиями, Андрей

1 ответ

Ну, smp_affinity - это битовая маска. Поскольку двоичные представления ваших чисел

1:  0000 0001
2:  0000 0010
4:  0000 0100
8:  0000 1000
16: 0001 0000

вы, очевидно, выбрали неправильные значения. Если "ff" не работает, попробуйте использовать "7", который должен установить битовую маску, чтобы позволить обработку прерываний процессорами 0-2. В противном случае определите "не работает" и опубликуйте результат cat /proc/irq/16/smp_affinity

Вы также можете прочитать эту статью в блоге, которая более подробно описывает сходство SMP.

Другие вопросы по тегам