天天看点

Linux网络实时流量监测工具——iftop

作者:RogenJiang

一款小巧但功能很强大的网络实时流量监测工具 iftop

运维过程中,总是有业务客户端反馈,业务平台访问太卡。但从现有网络设备的流量分析上查看分析,总是得不到结果。交换机上可以查到接口的流量情况,但流量是怎样分配的,是被哪些业务占用了,是没办法知道的。所以还是需要服务器做好监控。网上搜集了下,看有iftop这个工具,就尝试下。看看效果如何。也把监控和定位过程留下记录。

交换机根据IP地址找端口命令(华为交换机为例)

display arp | include x.x.x.x

此命令需要在网段的网关交换机上执行,一般都是核心交换机

Linux网络实时流量监测工具——iftop

查看eth-trunk的指向,在非常了解网络拓扑的情况,可以定位到下一级交换机

Linux网络实时流量监测工具——iftop

根据MAC在汇聚交换机查看对应的端口,找到端口,并查看流量信息

display mac-address | include fac2-c5ae-6800

Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop

iftop的安装过程

1、安装 iftop 必需的软件库

yum install  libpcap libpcap-devel ncurses ncurses-devel
yum install  flex byacc           
Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop

2、下载源码包,编译安装

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  运行出现报错,没C编译环境,安装GCC:yum install gcc
make
make install           
Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop

提示错误:configure: error: no acceptable C compiler found in $PATH

Linux网络实时流量监测工具——iftop

安装GCC

Linux网络实时流量监测工具——iftop

./configure执行成功

Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop
Linux网络实时流量监测工具——iftop

执行后,无报错,继续

2、iftop使用查看流量

iftop -P -i eth0,可以查看当前网络交互的流量情况

Linux网络实时流量监测工具——iftop

3、iftop 使用参数说明

参数含义                                                                                                                    示   例
 
-i指定需要监测的网卡                                                                                                iftop –i em1
-n将输出的主机信息都通过IP显示,不进行DNS反向解析                                          iftop -n
-B将输出以bytes为单位显示网卡流量,默认是bits                                                    iftop –B
-p以混杂模式运行iftop,此时iftop可以作为网络嗅探器使用                                     iftop –p
-N只显示连接端口号,不显示端口对应的服务名称                                                    iftop –N
-P显示主机以及端口信息,这个参数非常有用                                                           iftop –P
-F显示特定网段的网卡进出流量                                                                                iftop –F 192.168.12.0/24
-m设置iftop输出界面中最上面的流量刻度最大值,流量刻度分五个大段显示           iftop –m           

4、iftop 的交互操作

在 iftop 的实时监控界面中,还可以对输出结果进行交互式操作,用于对输出信息进行整理和过滤,在上图所示界面中,按键“h”即可进入交互选项界面,如下图所示:

Linux网络实时流量监测工具——iftop
参数  含义
P     通过此键可切换暂停/继续显示
h     通过此键可在交互参数界面/状态输出界面之间来回切换
b     通过此键可切换是否显示平均流量图形条
B     通过此键可切换显示2秒、10秒、40秒内的平均流量
T     通过此键可切换是否显示每个连接的总流量
j/k   按j键或k键可以向上或向下滚动屏幕显示当前的连接信息
l     通过此键可打开iftop输出过滤功能,比如输入要显示的IP,按回车后,屏幕就只显示与这个IP     相关的流量信息
L     通过此键可切换显示流量刻度范围,刻度不同,流量图形条会跟着变化
q     通过此键可退出iftop流量监控界面
n     通过此键可使iftop输出结果以IP或主机名的方式显示
s     通过此键可切换是否显示源主机信息
d     通过此键可切换是否显示远端目标主机信息
t     通过此键可切换iftop显示格式,连续按此键可依次显示:以两行方式显示发送接收流量、以一行方式显示发送接收流量、只显示发送流量/只显示接收流量
N     通过此键可切换显示端口号/端口号对应服务名称
S     通过此键可切换是否显示本地源主机的端口信息
D     通过此键可切换是否显示远端目标主机的端口信息
p     通过此键可切换是否显示端口信息
<     通过此键可根据左边的本地主机名或IP地址进行排序
>     通过此键可根据远端目标主机的主机名或IP地址进行排序
o     通过此键可切换是否固定显示当前的连接           

总结:

iftop 的强大之处在于它能够实时显示网络的流量状态,监控网卡流量的来源 IP 和目标地址,这对于检测服务器网络故障、流量异常是非常有用的,只需通过一个命令就能把流量异常或网络故障的原因迅速定位,因此对于运维人员来说,iftop 命令是必不可少的一个网络故障排查工具。