【Linux】iftop命令详解

2024-03-08 12:04
文章标签 linux 命令 详解 iftop

本文主要是介绍【Linux】iftop命令详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、iftop简介

二、安装iftop命令

2.1 命令查看测试环境系统信息

2.2 查看iftop版本与命令帮助

三、iftop的基本使用

3.1 直接使用iftop命令

3.2 iftop的显示说明

3.3 指定监控某块网卡

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

3.5 按照流量排序

3.6 过滤显示连接

3.7 快捷键


一、iftop简介


iftop命令是一种网络监测工具,它类似于Linux中的其他监测工具,如top、iotop等。但iftop是一个独立的命令,并不依赖于其他工具或服务。

iftop命令可以帮助我们查看服务器上网络接口的实时流量情况,包括流入和流出的数据量、数据包数量、流量占用比例等信息。此外,iftop还具有过滤、排序功能,用于更好地监测特定网络流量。


二、安装iftop命令


如果你的系统没有安装iftop命令,你需要使用如下命令来安装:

yum install  iftop -y

2.1 命令查看测试环境系统信息


2.2 查看iftop版本与命令帮助


显示版本iftop, version 1.0pre4

参数释义列表:

参数

释义

-h

显示帮助。

-n

不执行主机名DNS解析(即直接显示IP地址而不是主机名)

-N

不执行端口转换成服务操作(直接显示端口数字)

-p

运行在混杂模式(此时会显示整个网段中其他主机`部分`流量)

-b

不显示流量的图形条

-B

采用字节(bytes)显示带宽

-a

采用以包为单位的带宽

-i

监听在指定网络接口

-f

使用过滤代码来选择计数的数据包(默认是none,但是只计算IP包)

-F

IPv4 显示网络的in/out数据流

-G

IPv6 显示网络的in/out数据流

-l

打开屏幕过滤功能,输入要过滤的字符。比如输入相应IP地址,回车后,屏幕就只显示这个IP相关的流量信息。

-p

显示端口

-m

设置带宽等级的上限

-c

指定替代的配置文件

-t

使用不带ncurses 的文本界面,并将输出打印到STDOUT

-o 2s

第一列排序 (2s traffic average)


三、iftop的基本使用


3.1 直接使用iftop命令


直接输入iftop,默认监控的是第一块网卡。

可以使用 iftop 命令的 -n 选项,禁用主机名的解释。如果在正在运行的 iftop 会话中可以按 n 键打开或者关闭主机名的 DNS 解释。

3.2 iftop的显示说明


  • 第一部分

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

  • 第二部分
  1. 中间的<= =>这两个左右箭头,表示的是流量的方向。
  2. 其中又分别分为左、中、右三列。左列和中列,记录了哪些 IP 或主机正在和本机的网络进行连接。其中,中列的“=>”代表发送数据,“<=”代表接收数据,通过这个指示箭头可以很清晰地知道两个 IP 之间的通信情况。
  3. 最右列又分为三小列,这些实时参数分别表示外部 IP 连接到本机 2 秒内、10 秒内和 40 秒内的平均流量值。
  • 第三部分

分割线最下面的一部分,用来统计网卡流量信息。

TX:发送流量
RX:接收流量
TOTAL:总流量
Cumm:运行iftop到目前时间的总流量,也就是累计值
peak:流量峰值
rates:分别表示过去 2s 10s 40s 的平均流量

3.3 指定监控某块网卡


iftop -i ens33

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



iftop -F 192.168.2.110/24

3.5 按照流量排序


iftop可以按照流量大小对连接进行排序,从而帮助我们快速识别占用带宽较多的连接。通过按流量排序,我们可以发现网络中的瓶颈和异常情况。

排序方式

-o 2s:按第一列排序(2秒平均流量)

-o 10s:按第二列排序(10秒平均流量)【默认】

-o 40s:按第三列排序(40秒平均流量)

-o source:按源地址排序

-o destination:按目标地址排序

仅与-t选项同时使用的以下选项

-s num:在num秒后打印一次文本输出后退出

-L num:要打印的行数

示例: 网卡ens192 排序时间间隔 10s,在4秒后打印输出后退出

 iftop -n -i ens192 -o 10s -s 4  -t
  • -n选项表示只显示IP地址而非主机名,
  • -t选项表示在每一次更新后自动清除屏幕
  • -s 选项表示每4秒更新一次
  • -i 指定要监控的网口

3.6 过滤显示连接


我们可以使用iftop指令的过滤功能,只显示特定源IP地址或目标IP地址的连接。这对于定位特定主机的流量情况非常有用,帮助我们快速筛选和分析特定连接。

示例:

iftop -n -P -i ens192 -f "src port 1019"基于端口的过滤
iftop -f "port 80,443" 
基于IP基础和端口的过滤
iftop -f "src host 192.168.1.100 and dst port 80"
iftop -f "dst host 8.8.8.8"
  • -n 显示主机IP地址,而不是解析的主机名
  • -P 显示端口
  • i 执行网卡
  • -f 过滤数据包

3.7 快捷键


当你进入 iftop 会话时,你可以使用以下快捷键,切换 iftop 的显示方式或者按 f 添加过滤器。

  • h:显示帮助菜单
  • n:开启 / 关闭主机名的 DNS 解析,如果可以 iftop 可以将 IP 地址解释为主机名则显示主机的名称,否则显示 IP 地址。
  • N:开启 / 关闭服务名称的解释,例如,本地主机连接远程的主机的 443 端口,iftop 将会在远程主机 IP 地址后面添加服务的名称 www.myfreax.com:https。
  • p:开启 / 关闭目标和源端口的显示
  • P:暂停刷新屏幕,注意:
  • 这仅仅暂停主要窗口部分的刷新,屏幕底部的统计值依然自动刷新。
  • s:显示或者隐藏源主机的 IP 或主机名。
  • S:显示 / 关闭源端口。
  • t:切换显示发送和接收流量的三种方式,第一种是仅显示发送的流量,第二种是仅显示接收的流量,同时发送和接收的流量,也就是启动时的默认模式。
  • T:显示 / 关闭发送与接收流量统计,这将会在 2s 10s 40s 速率之前添加一列显示累计值。
  • q:退出 iftop

排序

  • j / k:分别是向下和向上滚动,当屏幕不足以显示所有连接时。
  • <:通过源名称的排序。
  • >:通过目标名称排序。
  • 1/2/3:通过第一,第二,第三列进行排序。
  • o:冻结排序方式,由于 iftop 是不断滚动所有连接,关闭 iftop 滚动连接,可以按 o 键。


参考原文链接:Linux下iftop指令详解_linux iftop-CSDN博客

原文链接:Linux系统之iftop的基本使用_linux iftop-CSDN博客

这篇关于【Linux】iftop命令详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/787027

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta