GNU/Linux >> Linux の 問題 >  >> Linux

KB/MB/Bytes 形式で、特定のポートまたはアプリケーションのプロセス ID について、Linux でリアルタイムのネットワーク統計を取得する方法を教えてください。

アプリケーションはおそらく、特定の UDP または TCP ポート番号、または特定の IP アドレスにパケットを送信しています。

したがって、TCPdump などを使用してそのトラフィックをキャプチャできます。

TCPdump は、必要なリアルタイムの統計情報を提供しませんが、その出力を何かにフィードすることができます (この回答を後で回答で更新しようとします)。

更新:

$ sudo tcpdump -i eth1 -l -e -n | ./netbps
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth1, link-type EN10MB (Ethernet), capture size 96 bytes
11:36:53    2143.33 Bps
11:37:03    1995.99 Bps
11:37:13    2008.35 Bps
11:37:23    1999.97 Bps
11:37:33    2083.32 Bps
131 packets captured
131 packets received by filter
0 packets dropped by kernel

1 分後に Ctrl+C を押して中断しました。

tcpdump の最後に適切なフィルター式を追加する必要があります アプリによって生成されたトラフィックのみを含めるコマンド (例:port 123 )

プログラム netbps これですか:

#!/usr/bin/perl
use strict;
use warnings;
use Time::HiRes;

my $reporting_interval = 10.0; # seconds
my $bytes_this_interval = 0;
my $start_time = [Time::HiRes::gettimeofday()];

STDOUT->autoflush(1);

while (<>) {
  if (/ length (\d+):/) {
    $bytes_this_interval += $1;
    my $elapsed_seconds = Time::HiRes::tv_interval($start_time);
    if ($elapsed_seconds > $reporting_interval) {
       my $bps = $bytes_this_interval / $elapsed_seconds;
       printf "%02d:%02d:%02d %10.2f Bps\n", (localtime())[2,1,0],$bps;
       $start_time = [Time::HiRes::gettimeofday()];
       $bytes_this_interval = 0;
    }
  }
}

これは一例です。お好みで調整してください。


同じフォルダから以下のように使用:

インターフェイスごとにパッカーを確認するには:./netpps.sh eth0

インターフェイスごとの速度を確認するには:./netspeed.sh eth0

インターフェイス netpps.sh で 1 秒あたりのパケット数を測定する ファイル名として

#!/bin/bash

INTERVAL="1"  # update interval in seconds

if [ -z "$1" ]; then
        echo
        echo usage: $0 [network-interface]
        echo
        echo e.g. $0 eth0
        echo
        echo shows packets-per-second
        exit
fi

IF=$1

while true
do
        R1=`cat /sys/class/net/$1/statistics/rx_packets`
        T1=`cat /sys/class/net/$1/statistics/tx_packets`
        sleep $INTERVAL
        R2=`cat /sys/class/net/$1/statistics/rx_packets`
        T2=`cat /sys/class/net/$1/statistics/tx_packets`
        TXPPS=`expr $T2 - $T1`
        RXPPS=`expr $R2 - $R1`
        echo "TX $1: $TXPPS pkts/s RX $1: $RXPPS pkts/s"
done

インターフェイス netspeed.sh でネットワーク帯域幅を測定する ファイル名として

#!/bin/bash

INTERVAL="1"  # update interval in seconds

if [ -z "$1" ]; then
        echo
        echo usage: $0 [network-interface]
        echo
        echo e.g. $0 eth0
        echo
        exit
fi

IF=$1

while true
do
        R1=`cat /sys/class/net/$1/statistics/rx_bytes`
        T1=`cat /sys/class/net/$1/statistics/tx_bytes`
        sleep $INTERVAL
        R2=`cat /sys/class/net/$1/statistics/rx_bytes`
        T2=`cat /sys/class/net/$1/statistics/tx_bytes`
        TBPS=`expr $T2 - $T1`
        RBPS=`expr $R2 - $R1`
        TKBPS=`expr $TBPS / 1024`
        RKBPS=`expr $RBPS / 1024`
        echo "TX $1: $TKBPS kB/s RX $1: $RKBPS kB/s"
done

詳細については、このサイトを参照してください http://xmodulo.com/measure-packets-per-second-throughput-high-speed-network-interface.html


最も使いやすく、出力を制御し、継続的なログ記録のためにファイルにリダイレクトするのが最も簡単です:

ifstat

おそらくほとんどの Linux ディストリビューションに付属しており、Mac では brew でインストールできます


Linux
  1. Linux –現在のプロセスでネットワークの共有を解除する方法は?

  2. Linux – Grindeq(Word用のlatexプラグイン)をWord In Wineで動作させる方法は?

  3. Linux –特定の単語をgrepしてテキストを取得する方法は?

  1. LinuxでNetworkManagerを使い始める

  2. Linux デスクトップでファイルに関連付けられたアイコン、MIME タイプ、およびアプリケーションを取得するにはどうすればよいですか?

  3. node.js を使用してシステム統計を取得する方法

  1. 特定のプロセスで実行されるユーザー、pid、およびコマンドのみを取得するにはどうすればよいですか? (Ubuntu 11.10)

  2. Linux の特定のポートで netstat を使用する方法

  3. Linux で、特定の宛先ホストへのルートに使用されているネットワーク インターフェイスと送信元 IP アドレスを確認するにはどうすればよいですか?