1.安装新版本
yum install libpcap libpcap-devel -y
wget
tar zxvf iftop-1.0pre4.tar.gz
cd iftop-1.0pre4
./configure --prefix=/usr/local/iftop10pre4/
make && make install
2、iftop界面相关说明
界面上面显示的是类似刻度尺的刻度范围,为显示流量图形的长条作标尺用的。
中间的<= =>这两个左右箭头,表示的是流量的方向。
TX:发送流量
RX:接收流量
TOTAL:总流量
Cumm:运行iftop到目前时间的总流量
peak:流量峰值
rates:分别表示过去 2s 10s 40s 的平均流量
3.常用的参数
-i设定监测的网卡,如:# iftop -i eth1
-B 以bytes为单位显示流量(默认是bits),如:# iftop -B
-n使host信息默认直接都显示IP,如:# iftop -n
-N使端口信息默认直接都显示端口号,如: # iftop -N
-F显示特定网段的进出流量,如# iftop -F 10.10.1.0/24或# iftop -F 10.10.1.0/255.255.255.0
-h(display this message),帮助,显示参数信息
-p使用这个参数后,中间的列表显示的本地主机信息,出现了本机以外的IP信息;
-b使流量图形条默认就显示;
-f这个暂时还不太会用,过滤计算包用的;
-P使host信息及端口信息默认就都显示;
-m设置界面最上边的刻度的最大值,刻度分五个大段显示,例:# iftop -m 100M
按n切换显示本机的IP或主机名;
按s切换是否显示本机的host信息;
按d切换是否显示远端目标主机的host信息;
按t切换显示格式为2行/1行/只显示发送流量/只显示接收流量;
按N切换显示端口号或端口服务名称;
按S切换是否显示本机的端口信息;
按D切换是否显示远端目标主机的端口信息;
按p切换是否显示端口信息;
按P切换暂停/继续显示;
按b切换是否显示平均流量图形条;
按B切换计算2秒或10秒或40秒内的平均流量;
按T切换是否显示每个连接的总流量;
按l打开屏幕过滤功能,输入要过滤的字符,比如ip,按回车后,屏幕就只显示这个IP相关的流量信息;
按L切换显示画面上边的刻度;刻度不同,流量图形条会有变化;
按j或按k可以向上或向下滚动屏幕显示的连接记录;
按1或2或3可以根据右侧显示的三列流量数据进行排序;
按<根据左边的本机名或IP排序;
按>根据远端目标主机的主机名或IP排序;
按o切换是否固定只显示当前的连接;
按f可以编辑过滤代码,这是翻译过来的说法,我还没用过这个!
常用命令:
/usr/local/iftop10pre4/sbin/iftop -N -n -P -i eth0
将iftop保存成文本脚本,nohup到后台就行了。
#!/bin/bash
Ifconfig="/sbin/ifconfig"
eth="eth0"
while true; do
TIME=$(date +'%Y%m%d%H%M%S')
RXpre=$($Ifconfig ${eth} | grep bytes | awk '{print $2}'| awk -F":" '{print $2}')
TXpre=$($Ifconfig ${eth} | grep bytes | awk '{print $6}' | awk -F":" '{print $2}')
sleep 1
RXnext=$($Ifconfig ${eth} | grep bytes | awk '{print $2}'| awk -F":" '{print $2}')
TXnext=$($Ifconfig ${eth} | grep bytes | awk '{print $6}' | awk -F":" '{print $2}')
TotalRXMin=$(expr `expr ${RXnext} - ${RXpre}` / 1048576)
TotalTXMin=$(expr `expr ${TXnext} - ${TXpre}` / 1048576)
if [ ${TotalTXMin} -gt 0 ];then
echo "$(date +'%Y-%m-%d %H:%M:%S') Total Recive: ${TotalRXMin}MB/s,Total Transfer:${TotalTXMin}MB/s" >> /tmp/lvs-net-mon.log
fi
if [[ ${TotalTXMin} -ge 1 ]];then
/usr/local/iftop10pre4/sbin/iftop -i ${eth} -N -P -t -L 50 -s 1 > /tmp/${TIME}.log
Filecount=$(ls /data/tcpdump/lvsflow*|wc -l)
#if [[ ${Filecount} -lt 100 ]];then
# tcpdump -nn -i ${eth} -w /data/tcpdump/ -Z root -C 10 -W 5 &
#else
# continue
#fi
else
continue
fi
done