Linux网络实时流量监测工具iftop的安装使用

概述:网络管理是基础运维中一个很重要的工作,在看似平静的网络运行中,其实暗流汹涌,要保证业务系统稳定运行,网络运维者必须要了解网络的流量状态、各个网段的使用情形,带宽的利用率、网络是否存在瓶颈等,同时,当网络发生故障时,必须能够及时发现问题,迅速定位问题,进而解决问题,这就需要一些网络监测工具的辅助,本节将介绍一款小巧但功能很强大的网络实时流量监测工具 iftop。

一、iftop 概述

iftop 是 Linux 系统一个免费的网卡实时流量监控工具,类似于 top 命令。iftop 可以监控指定网卡的实时流量、端口连接信息、反向解析 IP 等,还可以精确显示本机网络流量及网络内各主机和本机相互通信的流量集合,非常适合于监控代理服务器或路由器的网络流量。同时,iftop 对检测流量异常的主机非常有效,通过 iftop 的输出可以迅速定位主机流量异常的根源,这对于网络故障排查、网络安全检测是十分有用的。

二、iftop 安装

iftop 的官方网站为:http://www.ex-parrot.com/pdw/iftop/, 目前的最新稳定版本为 iftop-0.17。安装 iftop 非常简单,有源码编译安装和 yum 方式安装两种方式,这里以 Centos6.4 版本为例,简单介绍如下。

①、源码编译安装

安装 iftop 必需的软件库:

[root@localhost ~]#yum install  libpcap libpcap-devel ncurses ncurses-devel
[root@localhost ~]#yum install  flex byacc

前往iftop 官网下载最新的源码包,编译安装:

[root@localhost ~]#wget http://www.ex-parrot.com/pdw/iftop/download/iftop-0.17.tar.gz
[root@localhost ~]#tar zxvf iftop-0.17.tar.gz
[root@localhost ~]#cd iftop-0.17
[root@localhost ~]#./configure
[root@localhost ~]#make
[root@localhost ~]#make install

 ②、yum 在线安装

[root@localhost ~]#yum install  libpcap libpcap-devel ncurses ncurses-devel
[root@localhost ~]#yum install  flex byacc
[root@localhost ~]#wget http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm
[root@localhost ~]#rpm -ivh epel-release-6-8.noarch.rpm
[root@localhost ~]#yum install iftop

这样,iftop 就安装完成了。

三、iftop 使用

安装完 iftop 工具后,直接输入 iftop 命令即可显示网卡实时流量信息。在默认情况下,iftop 显示系统第一块网卡的流量信息,如果要显示指定网卡信息,可通过“-i”参数实现。

①、iftop 输出界面说明

执行“iftop -P -i em1”命令,得到如下图所示的 iftop 的一个典型输出界面:

iftop 的输出从整体上可以分为三大部分:

第一部分。是 iftop 输出中最上面的一行,此行信息是流量刻度,用于显示网卡带宽流量。

第二部分。是 iftop 输出中最大的一个部分,此部分又分为左、中、右三列,左列和中列记录了哪些 IP 或主机正在和本机的网络进行连接。其中,中列的“=>”代表发送数据,“<=”代表接收数据,通过这个指示箭头可以很清晰地知道两个 IP 之间的通信情况。最右列又分为三小列,这些实时参数分别表示外部 IP 连接到本机 2 秒内、10 秒内和 40 秒内的平均流量值。另外,这个部分还有一个流量图形条,流量图形条是对流量大小的动态展示,以第一部分中的流量刻度为基准。通过这个流量图形条可以很方便地看出哪个 IP 的流量最大,进而迅速定位网络中可能出现的流量问题。

第三部分位于 iftop 输出的最下面,可以分为三行,其中,“TX”表示发送数据,“RX”表示接收数据,“TOTAL”表示发送和接收全部流量。与这三行对应的有三列,其中“cum”列表示从运行 iftop 到目前的发送、接收和总数据流量。“peak”列表示发送、接收以及总的流量峰值。“rates”列表示过去 2s、10s、40s 的平均流量值。

②、iftop 使用参数说明

iftop 还有很多附加参数和功能。执行“iftop -h”即可显示 iftop 可使用的所有参数信息。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

③、iftop 的交互操作

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

iftop 的交互功能和 Linux 下的 top 命令非常类似,交互参数主要分为 4 个部分,分别是一般参数、主机显示参数、端口显示参数和输出排序参数。相关参数的含义如下表所示。

参数  含义
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 命令是必不可少的一个网络故障排查工具。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏程序员互动联盟

【记忆卡片】Linux sed命令

sed 在脚本使用时作用非常大,能完成很多更改功能,谁用谁知道 功能说明:利用script来处理文本文件。 语 法:sed [-hnV][-e<script>...

388130
来自专栏杨建荣的学习笔记

通过java程序抽取日志中的sql语句(r4笔记第4天)

今天在翻看以前的笔记时,发现自己在很早之前写过一个java程序,能够解析日志中的sql语句。 当时使用的环境是weblogic,日志目录下总是有几十上百个日志文...

32260
来自专栏杨建荣的学习笔记

vi的补充学习(r4笔记第25天)

今天突然发现vi虽然用了些日子了,但是常用的一些命令之外,还是有些命令比较生疏,简单总结了一下,然后自己在vi里面编辑了一把,效果还不错。 对于大家比较熟悉且常...

346100
来自专栏杨建荣的学习笔记

使用telnet命令验证邮箱(r4笔记第19天)

前些天在看一本shell脚本攻略的时候,里面有一个章节是通过curl命令来访问gmail邮箱,我在本地反复尝试,看来还是google服务在大陆受限的原因,一直都...

39360
来自专栏程序员互动联盟

【答疑释惑 第十讲】如何在windows下学习linux?

疑惑一 现在手游的server 端,一般都用哪种语言开发? 业界主要的是c/c++ + Python/lua模式做游戏服务器。c/c++做网络通讯数据传输,py...

42850
来自专栏程序员互动联盟

能让程序员心花怒放的七种礼物

一般偏感性的人都容易用小礼物哄的开心,比如从路边摘一朵送给一个小姑娘,她会开心好几天。但对一些偏理性的人,就很难用一个简单的礼物打动他了。以开发软件为职业的程...

37570
来自专栏杨建荣的学习笔记

巧用linux命令做图片下载器(r4笔记第7天)

在平时上网的时候,发现有些图片不错,想保存到本地,一个一个的保存确实够费劲的,如果把整个网页都保存了,有些又是自己不需要的,就算下载下来了,还得从上百个网页元素...

43260
来自专栏程序员互动联盟

【记忆卡片】linux网络命令

一、ifconfig是查看网卡的信息 ifconfig [Interface] Interface是可选项,如果不加此项,则显示系统中所有网卡的信息。如果添加此...

35450
来自专栏杨建荣的学习笔记

通过Linu命令实现屏幕录制和回放(r4笔记第5天)

平时在工作学习中如果可以录屏的话,那么在以后再看真是很难得的学习资料。有些远程的操作都是命令行,如果使用录屏软件,可能占用的空间极大。其实Linux中可以通过命...

31060
来自专栏程序员互动联盟

【答疑解惑第九讲】如何在linux下面编译一个简单的c语言程序

存在问题: 习惯了用IDE,习惯了点击执行按钮。在linux就不能这样了,该咋办? 解决方案: 随着android的大热,在linux下搞开发的人也越来越多,好...

396110

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励