在Linux系统中,监控网络带宽使用情况是系统管理和网络故障排查的重要环节,通过查看带宽,可以识别网络拥堵、异常流量占用、性能瓶颈等问题,Linux提供了多种命令行工具和系统监控方法,支持实时流量查看、历史数据统计、进程级流量分析等功能,本文将详细介绍常用的带宽查看工具及其使用方法,帮助用户根据实际需求选择合适的监控方案。

实时网络流量监控工具
实时监控工具能够动态展示当前网络接口的带宽使用情况,适用于临时排查网络拥堵或观察实时流量变化。
iftop:按主机/端口排序的实时流量监控
iftop是一款基于libpcap的实时流量监控工具,以列表形式显示网络接口的实时带宽使用,支持按源/目标IP、端口排序,并直观展示流量流向。
-
安装方法:
- Ubuntu/Debian:
sudo apt install iftop - CentOS/RHEL:
sudo yum install iftop - 源码编译:需安装
libpcap-dev和ncurses-dev,从官网下载源码后./configure && make && sudo make install
- Ubuntu/Debian:
-
使用示例:
基本用法:sudo iftop -i eth0(指定监控网卡,默认为第一个活跃接口)
常用参数:-n:不显示主机名,仅显示IP(避免DNS解析延迟)-N:不显示端口名称,仅显示端口号-t:不显示流量条形图,仅显示数值-P:显示端口信息(默认按主机排序,开启后按端口排序)-p:启用混杂模式(监控所有通过接口的流量,包括非本机流量)
-
输出解读:
=> 发送流量,<= 接收流量 行:`TX`(发送)、`Cumulative`(累计流量)、`Peak`(峰值流量) �表层:`SOURCE`(源IP/端口)、`=>`(发送速率)、`<=`(接收速率)、`TOTAL`(总速率)、`Pkts`(数据包数量)
nethogs:按进程统计实时流量
nethogs以进程为单位监控网络带宽使用,适合快速定位占用带宽的高进程(如下载工具、视频软件等)。
-
安装方法:
- Ubuntu/Debian:
sudo apt install nethogs - CentOS/RHEL:
sudo yum install nethogs
- Ubuntu/Debian:
-
使用示例:
基本用法:sudo nethogs(默认监控所有活跃接口)
指定接口:sudo nethogs eth0
参数:-d:刷新间隔(秒,默认为1)-t:显示/隐藏程序路径-c:刷新次数(如nethogs -c 5仅刷新5次后退出)
-
输出解读:
PID PROGRAM DEV SENT RECEIVED 1234 wget eth0 1.2MB 0B 5678 chrome eth0 5.6MB 12.3MB每行显示进程ID、程序名、网络接口、发送/接收流量,按实时流量排序。
bmon:可视化带宽监控
bmon(Bandwidth Monitor)以文本界面图形化展示网络流量,支持多接口监控和流量历史曲线,适合需要直观流量趋势的场景。

-
安装方法:
- Ubuntu/Debian:
sudo apt install bmon - CentOS/RHEL:
sudo yum install bmon
- Ubuntu/Debian:
-
使用示例:
基本用法:sudo bmon
交互操作:i:切换监控接口l:显示/隐藏流量曲线d:显示/隐藏详细统计q:退出
历史流量统计工具
实时监控无法反映长期流量趋势,历史统计工具通过记录网络接口的流量数据,支持按天/周/月统计,适合分析带宽使用规律。
vnstat:轻量级流量统计
vnstat通过读取/proc/net/dev接口数据,定期记录并统计网络流量,无需长时间运行后台进程,资源占用低。
-
安装方法:
- Ubuntu/Debian:
sudo apt install vnstat - CentOS/RHEL:
sudo yum install vnstat
- Ubuntu/Debian:
-
初始化数据库:
首次使用需初始化数据库(指定接口):sudo vnstat -u -i eth0
设置为开机自启(CentOS):sudo systemctl enable vnstat -
使用示例:
查看实时流量:vnstat
查看指定接口统计:vnstat -i eth0
查看历史数据:vnstat -d:按天统计vnstat -w:按周统计vnstat -m:按月统计vnstat --oneline:单行显示汇总信息
-
输出解读:
eth0 since 2023-10-01 rx: 123.45 GiB tx: 67.89 GiB total: 191.34 GiB current: 12.3 Mbps (rx: 8.9 Mbps, tx: 3.4 Mbps)显示总流量、当前实时速率及历史统计周期。
sar:系统活动报告工具
sar是sysstat包的一部分,可记录系统各项活动(包括网络流量),通过/var/log/sysstat/目录下的数据文件生成历史报告。
-
安装方法:

- Ubuntu/Debian:
sudo apt install sysstat - CentOS/RHEL:
sysstat通常已预装,否则sudo yum install sysstat
- Ubuntu/Debian:
-
启用数据收集:
编辑/etc/default/sysstat,将ENABLED="false"改为ENABLED="true",然后重启服务:sudo systemctl restart sysstat -
使用示例:
查看当日网络流量:sar -n DEV
查看指定日期的历史数据:sar -n DEV -s 08:00:00 -e 18:00:00 20231001
参数:-n DEV:显示网络接口统计-s/-e:指定时间范围-f:读取指定数据文件(如/var/log/sysstat/sa10)
-
输出解读:
10:00:01 IFACE rxpck/s txpck/s rxkB/s txkB/s 10:10:01 eth0 1250.00 800.00 150.23 95.67显示每秒接收/发送的数据包数(rxpck/s/txpck/s)和带宽(rxkB/s/txkB/s)。
网络接口统计与系统文件查看
ip命令:查看接口详细统计
ip是Linux下强大的网络配置工具,通过ip -s link可查看网络接口的详细流量统计,包括接收/发送的字节数、包数、错误数等。
- 使用示例:
ip -s link show eth0
输出:2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP mode DEFAULT group default qlen 1000 link/ether 00:1c:23:45:67:89 brd ff:ff:ff:ff:ff:ff RX: bytes packets errors dropped overrun mcast 12345678 123456 0 0 0 123 TX: bytes packets errors dropped carrier collsns 8765432 87654 0 0 0 0RX/TX分别表示接收/发送方向的统计,bytes为总字节数,packets为总包数。
/proc/net/dev:内核原始数据
/proc/net/dev是内核提供的网络接口统计文件,可直接查看或通过脚本解析,适合自动化监控。
- 使用示例:
cat /proc/net/dev
输出:Inter-| Receive | Send face |bytes packets errs drop fifo frame compressed multicast|bytes packets errs drop fifo colls carrier compressed eth0: 12345678 123456 0 0 0 0 0 123 8765432 87654 0 0 0 0 0 0第一列为接口名,后续为接收(Receive)和发送(Send)方向的统计指标。
常用带宽监控工具对比
| 工具名称 | 功能特点 | 实时性 | 是否需安装 | 适用场景 |
|---|---|---|---|---|
| iftop | 按主机/端口排序,显示流量流向 | 实时 | 是 | 实时流量分析,定位IP/端口占用 |
| nethogs | 按进程统计流量 | 实时 | 是 | 定位高带宽进程 |
| bmon | 图形化流量曲线 | 实时 | 是 | 直观查看流量趋势 |
| vnstat | 轻量级历史流量统计 | 非实时 | 是 | 长期流量分析,带宽规划 |
| sar | 系统活动历史报告 | 非实时 | 需安装sysstat | 企业级历史数据审计 |
| ip -s link | 接口详细统计 | 实时 | 系统内置 | 快速查看接口基础指标 |
| /proc/net/dev | 内核原始数据 | 实时 | 系统内置 | 脚本自动化监控 |
相关问答FAQs
Q1:iftop显示的TX/RX分别代表什么?如何解读流量数值的单位?
A:iftop中,TX(Transmit)表示发送流量,RX(Receive)表示接收流量,=>指向的列是当前连接的发送速率,<=指向的列是接收速率,流量数值的单位默认为bits/s(比特/秒),若显示为Kb/s、Mb/s,则分别表示千比特/秒、兆比特/秒(注意:1 Byte=8 bits,因此带宽数值通常比文件传输速率高8倍),显示10 Mb/s表示当前传输速率为10兆比特/秒,即1.25兆字节/秒。
Q2:如何查看某个特定进程的实时带宽占用,并持续监控?
A:可结合nethogs和watch命令实现,首先使用nethogs查看进程流量,并通过watch定时刷新,监控名为chrome的进程:sudo watch -n 1 "nethogs | grep chrome"。-n 1表示每秒刷新一次,grep chrome过滤出chrome进程的流量信息,若需监控特定接口(如eth0),可添加-i eth0参数:sudo watch -n 1 "nethogs -i eth0 | grep chrome",输出中会实时显示chrome进程的发送/接收速率,便于持续观察其带宽占用情况。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/31554.html