Назад | Перейти на главную страницу

Мониторинг объема сетевого трафика через интерфейс

Есть ли способ отслеживать трафик (например, получать представление об использовании в реальном времени) через определенный сетевой интерфейс, например, eth0?

Загвоздка здесь в том, что набор инструментов на коробке фиксирован и в значительной степени представляет собой стандартное развертывание RHEL, поэтому дополнительные инструменты использовать нельзя.

Ищете что-то базовое и обычно такое, как iostat.

Данные, которые вы хотите видеть, отображаются в старом-добром ifconfig.

watch ifconfig eth0

или чтобы все было лучше:

watch -n 1 -d ifconfig eth0

Я использую команду iftop. Показывает статистику в реальном времени.

iftop -i eth0

Посмотрите несколько скриншотов здесь:

http://www.thegeekstuff.com/2008/12/iftop-guide-display-network-interface-bandwidth-usage-on-linux/

function humanValue()
{
    h=( '' K M G T P )
    i=1; v=$(( $1 * 8 ))
    while [ $v -gt $(( 1 << 10 * i )) ]; do let i++; done;
    echo -n "$(( $v >> 10 * --i )) ${h[i]}b/s";
}
ifaces=$(ip addr | grep -E "^[0-9]:" | cut -d" " -f2 | tr -d \:)
declare -A RX2 TX2;
while sleep 1; 
do
    date 
    for INTERFACE in $ifaces;
    do
        RX1=$(cat /sys/class/net/${INTERFACE}/statistics/rx_bytes)
        TX1=$(cat /sys/class/net/${INTERFACE}/statistics/tx_bytes)
        DOWN=$(( RX1 - RX2[$INTERFACE] ))
        UP=$(( TX1 - TX2[$INTERFACE] ))
        RX2[$INTERFACE]=$RX1; TX2[$INTERFACE]=$TX1
        echo -e "[ $INTERFACE:\tRX: $(humanValue $DOWN)\t|\tTX: $(humanValue $UP) ]"
    done;
done;

на Linux после 2015 года это может быть лучше watch -n1 -d ip -s link show [interface]

Без установки новых инструментов:

while ifconfig eth0 | grep 'RX bytes'; do sleep 10; done

Есть много утилит:

  1. Nethogs
  2. iptraf
  3. Iptables может быть хорошим решением, но если вы используете брандмауэр, будет немного сложно правильно переместить правила.

Вы также можете использовать iptables, чтобы подумать:

iptables -A INPUT -p tcp --dport $port -i eth0

и

iptables -A OUTPUT -p tcp --sport $port -i eth0

Затем iptables -L -n -v напечатает, сколько пакетов прошло через интерфейс, iptables -Z обнулит этот счетчик

Взгляни на ntop. Он предоставляет много подробных данных.