Chinaunix首页 | 论坛 | 博客
  • 博客访问: 226487
  • 博文数量: 70
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 440
  • 用 户 组: 普通用户
  • 注册时间: 2015-08-09 09:16
个人简介

淡泊以明志,宁静以致远。

文章分类

全部博文(70)

分类: LINUX

2015-09-25 14:39:16

iftop

介绍

iftop是一款实时流量监控工具,监控TCP/IP连接等,缺点就是无报表功能。必须以root身份才能运行。


1、前提条件安装


# yum install flex byacc libpcap ncurses ncurses-devel libpcap-devel
 
2、下载iftop源码包
# wget
或者下载RPM安装包(适用于RHEL6 and CentOS-6 x86 64bit
# wget
 
3、编译安装iftop
# tar xvf iftop-0.17.tar.gz
# cd iftop-0.17
# ./configure --prefix=/usr/local/iftop
# make
# make install
或者采用RPM的方式安装(适用于RHEL6 and CentOS-6 x86 64bit)
# rpm -ivh iftop-1.0-0.pre3.el6.rf.x86_64.rpm

4、添加环境变量
# /usr/local/iftop/sbin/iftop <可把此路径写进环境变量>

修改/etc/profile文件使其永久性生效,并对所有系统用户生效,在文件末尾加上如下两行代码
PATH=$PATH:/usr/local/iftop/sbin
export PATH

最后:执行 命令 source /etc/profile 使其修改生效,执行完可通过echo $PATH命令查看是否添加成功。

 
5、相关参数及说明
<1、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 退出监控。

6.实例

默认是监控第一块网卡的流量

iftop

监控eth1

iftop -i eth1

直接显示IP, 不进行DNS反解析

iftop -n 

直接显示连接埠编号, 不显示服务名称:

iftop -N 

显示某个网段进出封包流量

iftop -F 192.168.1.0/24 or 192.168.1.0/255.255.255.0


基于实例讲解输出含义

执行iftop -N -n -i eth1后界面为

19.1Mb            38.1Mb              57.2Mb               76.3Mb             95.4Mb
+-----------------+-----------------+--------------------+--------------------+---------------------
192.168.1.11                                  => 192.168.1.66                  5.3Mb  3.22Mb  3.20Mb
                                              <=                               219kb  45.7kb  49.3kb
192.168.1.11                                   => 192.168.1.29                 144kb  30.8kb  29.6kb
                                              <=                               11.3Mb  2.38Mb  2.74Mb
192.168.1.11                                  => 12.2.11.71                    0b   6.40kb  6.66kb
                                              <=                               0b      0b      0b
192.168.1.11                                  => 192.168.1.8                   2.63kb  1.43kb   932b
                                              <=                               1.31kb  1.05kb   893b
192.168.1.11                                   => 192.168.2.78                 2.53kb  1.54kb  2.15kb
                                               <=                              160b    160b    187b
192.168.1.11                                   => 111.126.195.69               0b    166b     69b
                                               <=                              0b      0b      0b
------------------------------------------------------------------------------------------------------
TX:             cum:   9.70MB   peak:   15.6Mb                          rates:   15.4Mb  3.26Mb  3.23Mb
RX:                    8.38MB           14.9Mb                                   11.5Mb  2.42Mb  2.79Mb
TOTAL:                 18.1MB           30.5Mb                                   27.0Mb  5.69Mb  6.03Mb

iftop界面含义如下

复制代码
第一行:带宽显示

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

中间部分右边:实时参数分别是该访问ip连接到本机2秒,10秒和40秒的平均流量 =>代表发送数据,<= 代表接收数据

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

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

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

底部三行第四列:为平均值
复制代码

通过iftop的界面很容易找到哪个ip在霸占网络流量,这个是ifstat做不到的。不过iftop的流量显示单位是Mb,这个b是bit,是位,不是字节,而ifstat的KB,这个B就是字节了,byte是bit的8倍。初学者容易被误导。

原文地址:

http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2858923.html

另一种简单的方法

阅读(1540) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~