Коротко.
Некоторые записи (например incomplete и на 169.254.0.0/16) из arp-таблицы (/proc/net/arp) не удаляются ни по adp -d IP ни по arp -i IFACE -d IP ни по ip neigh flush dev DEV, зато отлично удаляются по ip li se arp off DEV; ip li se arp on DEV
Надо распределить много прерываний от кучи сетевых карт по ядрам?
У меня вот подвернулся сервер с 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=1for 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 fidone
Да, я знаю про существование irqbalance, который в автоматическом режиме умеет следить и распределятьпрерывания, но как показывает практика, делает он это крайне неоптимально и далеко не всегда становится лучше.