在Linux中有很多的流量監(jiān)控工具,它們可以監(jiān)控、分類網(wǎng)絡(luò)流量,以花哨的圖形用戶界面提供實(shí)時(shí)流量分析報(bào)告。大多數(shù)這些工具(例如:ntopng,iftop)都是基于libpcap庫(kù)的 ,這個(gè)函數(shù)庫(kù)是用來截取流經(jīng)網(wǎng)卡的數(shù)據(jù)包的,可在用戶空間用來監(jiān)視分析網(wǎng)絡(luò)流量。盡管這些工具功能齊全,然而基于libpcap庫(kù)的流量監(jiān)控工具無法處理高速(Gb以上)的網(wǎng)絡(luò)接口,原因是由于在用戶空間做數(shù)據(jù)包截取的系統(tǒng)開銷過高所致。
在本文中我們介紹一種簡(jiǎn)單的Shell 腳本,它可以監(jiān)控網(wǎng)絡(luò)流量而且不依賴于緩慢的libpcap庫(kù)。這些腳本支持Gb以上規(guī)模的高速網(wǎng)絡(luò)接口,如果你對(duì)“匯聚型”的網(wǎng)絡(luò)流量感興趣的話,它們可統(tǒng)計(jì)每個(gè)網(wǎng)絡(luò)接口上的流量。
腳本主要是基于sysfs虛擬文件系統(tǒng),這是由內(nèi)核用來將設(shè)備或驅(qū)動(dòng)相關(guān)的信息輸出到用戶空間的一種機(jī)制。網(wǎng)絡(luò)接口的相關(guān)分析數(shù)據(jù)會(huì)通過“/sys/class/net//statistics”輸出。
舉個(gè)例子,eth0的網(wǎng)口上分析報(bào)告會(huì)輸出到這些文件中:
/sys/class/net/eth0/statistics/rx_packets:收到的數(shù)據(jù)包數(shù)據(jù)
/sys/class/net/eth0/statistics/tx_packets:傳輸?shù)臄?shù)據(jù)包數(shù)量
/sys/class/net/eth0/statistics/rx_bytes:接收的字節(jié)數(shù)
/sys/class/net/eth0/statistics/tx_bytes:傳輸?shù)淖止?jié)數(shù)
/sys/class/net/eth0/statistics/rx_dropped:當(dāng)收到包數(shù)據(jù)包下降的數(shù)據(jù)量
/sys/class/net/eth0/statistics/tx_dropped:傳輸包數(shù)據(jù)包下降的數(shù)據(jù)量
這些數(shù)據(jù)會(huì)根據(jù)內(nèi)核數(shù)據(jù)發(fā)生變更的時(shí)候自動(dòng)刷新。因此,你可以編寫一系列的腳本進(jìn)行分析并計(jì)算流量統(tǒng)計(jì)。下面就是這樣的腳本。第一個(gè)腳本是統(tǒng)計(jì)每秒數(shù)據(jù)量,包含接收(RX)或發(fā)送(TX)。而后面的則是一個(gè)描述網(wǎng)絡(luò)傳輸中的接收(RX)發(fā)送(TX)帶寬。這些腳本中安裝不需要任何的工具。
測(cè)量網(wǎng)口每秒數(shù)據(jù)包:
#!/bin/bash
INTERVAL="1"# update interval in seconds
if[ -z"$1"];then
echo
echo usage: $0[network-interface]
echo
echoe.g.$0eth0
echo
echo shows packets-per-second
exit
fi
IF=$1
whiletrue
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
網(wǎng)絡(luò)帶寬測(cè)量
#!/bin/bash
INTERVAL="1"# update interval in seconds
if[ -z"$1"];then
echo
echo usage: $0[network-interface]
echo
echoe.g.$0eth0
echo
exit
fi
IF=$1
whiletrue
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
下面的屏幕截圖顯示了上面的兩個(gè)腳本的輸出。
-
Linux
+關(guān)注
關(guān)注
87文章
11292瀏覽量
209323 -
網(wǎng)絡(luò)流量
+關(guān)注
關(guān)注
0文章
58瀏覽量
10364
原文標(biāo)題:如何在 Linux 下統(tǒng)計(jì)高速網(wǎng)絡(luò)中的流量
文章出處:【微信號(hào):LinuxHub,微信公眾號(hào):Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論