且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

Linux流量监控工具 - iftop

更新时间:2022-06-12 22:57:38

Linux流量监控工具 - iftop

------------------------------------------------------------------------------------- 

iftop脚本安装,下载脚本放到/usr/local/sbin/目录下:

iftop脚本参考咐件!重命名为:iftop.sh

 

#!/bin/bash
echo "正在检查安装系统依赖包,请稍等......"
yum install -y gcc gcc-c++ libpcap libpcap-devel ncurses ncurses-devel flex byacc
echo "正在下载iftop主程序包......"
DOWNLOAD=/usr/local/src/
cd ${DOWNLOAD}
wget 
http://www.ex-parrot.com/~pdw/iftop/download/iftop-0.17.tar.gz
echo "正在解压和编译iftop主程序包...."
tar zxvf iftop-0.17.tar.gz 
cd iftop-0.17
./configure 
echo "请选择安装
         继续安装 请输入Y\y
         退出     请输入N\n
"
read -p "请根据编号选择(Y\y or N\n).. " SERVER_ID
if [ $SERVER_ID == Y ] || [ $SERVER_ID == y ];then
        SERVER="继续安装"
elif [ $SERVER_ID == N ] || [ $SERVER_ID == n ];then
        SERVER="Quit"
 exit 5
else
        exit
fi
echo "安装正在进行中,请稍等...."
make && make install 
echo "安装成功,请使用......"


 

注意:必须赋予权限运行:#chmod 755 iftop.sh 或 #chmod +x iftop.sh 

                        #./iftop.sh或 sh iftop.sh

-------------------------------------------------------------------------------------

 

Linux系统中可以使用top查看系统资源、进程、内存占用等信息。查看网络状态可以使用netstat、nmap等工具。若要查看实时的网络流量,监控TCP/IP连接等,则可以使用iftop。iftop可以用来监控网卡的实时流量(可以指定网段)、反向解析IP、显示端口信息等,详细的将会在后面的使用参数中说明。

 

下面以CentOS-6.3-i386-bin-DVD1安装iftop

安装方法1、编译安装

如果采用编译安装可以到iftop官网下载最新的源码包。

安装前需要已经安装好基本的编译所需的环境,比如make、gcc、autoconf等。安装iftop还需要安装libpcap和libcurses。

CentOS上安装所需依赖包:

#yum install flex byacc libpcap ncurses ncurses-devel libpcap-devel

 

下载iftop

#wget http://www.ex-parrot.com/pdw/iftop/download/iftop-0.17.tar.gz

#tar zxvf iftop-0.17.tar.gz

#cd iftop-0.17

#./configure

#make && make install

 

安装方法2、RPM包安装

CentOS系统:

#yum install flex byacc libpcap ncurses ncurses-devel

#wget ftp://fr2.rpmfind.net/linux/dag/redhat/el5/en/i386/dag/RPMS/iftop-0.17-1.el5.rf.i386.rpm

#rpm -ivh iftop-0.17-1.el5.rf.i386.rpm

 

运行iftop

直接运行: #iftop

效果如下图:

Linux流量监控工具 - iftop

相关参数及说明

1、iftop界面相关说明

第一行:带宽显示

中间部分:外部连接列表,即记录了哪些ip正在和本机的网络连接

中间部分右边:实时参数分别是该访问ip连接到本机2秒,10秒和40秒的平均流量

=>代表发送数据,<= 代表接收数据

底部三行:表示发送,接收和全部的流量

底部三行第二列:为你运行iftop到目前流量

底部三行第三列:为高峰值

底部三行第四列:为平均值

界面上面显示的是类似刻度尺的刻度范围,为显示流量图形的长条作标尺用的。

中间的<= =>这两个左右箭头,表示的是流量的方向。

TX:发送流量

RX:接收流量

TOTAL:总流量

Cumm:运行iftop到目前时间的总流量

peak:流量峰值

rates:分别表示过去 2s 10s 40s 的平均流量

 

2、iftop相关参数

常用的参数

-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

进入iftop画面后的一些操作命令(注意大小写)

按h切换是否显示帮助;

按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可以编辑过滤代码,这是翻译过来的说法,我还没用过这个!

按!可以使用shell命令,这个没用过!没搞明白啥命令在这好用呢!

按q退出监控。

 

常见问题

1、make: yacc: Command not found

make: *** [grammar.c] Error 127

解决方法:#yum install byacc

 

2、configure: error: Curses! Foiled again!

(Can't find a curses library supporting mvchgat.)

Consider installing ncurses.

解决方法: #yum install ncurses-devel




本文转自 yhw85 51CTO博客,原文链接:http://blog.51cto.com/yanghuawu/951834,如需转载请自行联系原作者