smp affinity для многоядерных систем

Надо распределить много прерываний от кучи сетевых карт по ядрам?
У меня вот подвернулся сервер с 16 потоками и 13 сетевыми картами, каждая из которых создаёт по несколько (8-9) очередей. Руками раскидывать очереди по ядрам – мартышкина работа.
Скрипт поможет!

#!/bin/bash
# Посмотреть:
# grep eth /proc/interrupts | sed 's/PCI-MSI-edge//g;s/  / /g;s/  / /g;s/  / /g;s/  / /g;s/ /\t/g'
# Помониторить:
# watch -n1 "grep eth /proc/interrupts | sed 's/://g;s/PCI-MSI-edge//g;s/  / /g;s/  / /g;s/  / /g;s/  / /g;s/ /\t/g' "

CORE=1
for INTERRUPT in $( grep eth /proc/interrupts | sed 's/://g' | awk '{print $1 }' ); do
# echo core: $CORE interrupt: $INTERRUPT
 echo $CORE > /proc/irq/$INTERRUPT/smp_affinity
 CORE=`echo "$CORE * 2" | bc`
 if [ "$CORE" -gt "32768" ]; then
   CORE=1
 fi
done

Да, я знаю про существование irqbalance, который в автоматическом режиме умеет следить и распределятьпрерывания, но как показывает практика, делает он это крайне неоптимально и далеко не всегда становится лучше.

| опубликовано: Дек 2, 03:25

  Помощь по Textile