学会这 18 个工具,你必定能真正理解如何监控网络带宽!

本文介绍了一些能够用来监控网络使用状况的Linux命令行工具。这些工具能够监控经过网络接口传输的数据,并测量目前哪些数据所传输的速度。入站流量和出站流量分开来显示。python

一些命令能够显示单个进程所使用的带宽。这样一来,用户很容易发现过分使用网络带宽的某个进程。ios

这些工具使用不一样的机制来制做流量报告。nload等一些工具能够读取"proc/net/dev"文件,以得到流量统计信息;而一些工具使用pcap库来捕获全部数据包,而后计算总数据量,从而估计流量负载。服务器

下面是按功能划分的命令名称。网络

  • 监控整体带宽使用――nload、bmon、slurm、bwm-ng、cbm、speedometer和netload
  • 监控整体带宽使用(批量式输出)――vnstat、ifstat、dstat和collectl
  • 每一个套接字链接的带宽使用――iftop、iptraf、tcptrack、pktstat、netwatch和trafshow
  • 每一个进程的带宽使用――nethogs

一、nloaddom

nload是一个命令行工具,让用户能够分开来监控入站流量和出站流量。它还能够绘制图表以显示入站流量和出站流量,视图比例能够调整。用起来很简单,不支持许多选项。tcp

因此,若是你只须要快速查看总带宽使用状况,无需每一个进程的详细状况,那么nload用起来很方便。工具

安装nload:Fedora和Ubuntu在默认软件库里面就有nload。CentOS用户则须要从Epel软件库得到nload。spa

二、iftop命令行

iftop可测量经过每个套接字链接传输的数据;它采用的工做方式有别于nload。iftop使用pcap库来捕获进出网络适配器的数据包,而后汇总数据包大小和数量,搞清楚总的带宽使用状况。3d

虽然iftop报告每一个链接所使用的带宽,但它没法报告参与某个套按字链接的进程名称/编号(ID)。不过因为基于pcap库,iftop可以过滤流量,并报告由过滤器指定的所选定主机链接的带宽使用状况。

n选项能够防止iftop将IP地址解析成主机名,解析自己就会带来额外的网络流量。

安装iftop:Ubuntu/Debian/Fedora用户能够从默认软件库得到它。CentOS用户能够从Epel得到它。

三、iptraf

iptraf是一款交互式、色彩鲜艳的IP局域网监控工具。它能够显示每一个链接以及主机之间传输的数据量。下面是屏幕截图。

安装iptraf:

四、nethogs

nethogs是一款小巧的"net top"工具,能够显示每一个进程所使用的带宽,并对列表排序,将耗用带宽最多的进程排在最上面。万一出现带宽使用忽然激增的状况,用户迅速打开nethogs,就能够找到致使带宽使用激增的进程。nethogs能够报告程序的进程编号(PID)、用户和路径。

安装nethogs:Ubuntu、Debian和Fedora用户能够从默认软件库得到。CentOS用户则须要Epel。

5. bmon

bmon(带宽监控器)是一款相似nload的工具,它能够显示系统上全部网络接口的流量负载。输出结果还含有图表和剖面,附有数据包层面的详细信息。

安装bmon:Ubuntu、Debian和Fedora用户能够从默认软件库来安装。CentOS用户则须要安装repoforge,由于Epel里面没有bmon。

6. slurm

slurm是另外一款网络负载监控器,能够显示设备的统计信息,还能显示ASCII图形。它支持三种不一样类型的图形,使用c键、s键和l键便可激活每种图形。slurm功能简单,没法显示关于网络负载的任何更进一步的详细信息。

安装slurm

7. tcptrack

tcptrack相似iftop,使用pcap库来捕获数据包,并计算各类统计信息,好比每一个链接所使用的带宽。它还支持标准的pcap过滤器,这些过滤器可用来监控特定的链接。

安装tcptrack:Ubuntu、Debian和Fedora在默认软件库里面就有它。CentOS用户则须要从RepoForge得到它,由于Epel里面没有它。

8. vnstat

vnstat与另外大多数工具备点不同。它实际上运行后台服务/守护进程,始终不停地记录所传输数据的大小。以外,它能够用来制做显示网络使用历史状况的报告

运行没有任何选项的vnstat,只会显示自守护进程运行以来所传输的数据总量。

想实时监控带宽使用状况,请使用"-l"选项(实时模式)。而后,它会显示入站数据和出站数据所使用的总带宽量,但很是精确地显示,没有关于主机链接或进程的任何内部详细信息。

vnstat更像是一款制做历史报告的工具,显示天天或过去一个月使用了多少带宽。它并非严格意义上的实时监控网络的工具。

vnstat支持许多选项,支持哪些选项方面的详细信息请参阅参考手册页。

安装vnstat

9. bwm-ng

bwm-ng(下一代带宽监控器)是另外一款很是简单的实时网络负载监控工具,能够报告摘要信息,显示进出系统上全部可用网络接口的不一样数据的传输速度。

若是控制台足够大,bwm-ng还能使用curses2输出模式,为流量绘制条形图。

安装bwm-ng:在CentOS上,能够从Epel来安装bwm-ng。

10. cbm:Color Bandwidth Meter

这是一款小巧简单的带宽监控工具,能够显示经过诸网络接口的流量大小。没有进一步的选项,仅仅实时显示和更新流量的统计信息。

11. speedometer

这是另外一款小巧而简单的工具,仅仅绘制外观漂亮的图形,显示经过某个接口传输的入站流量和出站流量。

安装speedometer

12. pktstat

pktstat能够实时显示全部活动链接,并显示哪些数据经过这些活动链接传输的速度。它还能够显示链接类型,好比TCP链接或UDP链接;若是涉及HTTP链接,还会显示关于HTTP请求的详细信息。

13. netwatch

netwatch是netdiag工具库的一部分,它也能够显示本地主机与其余远程主机之间的链接,并显示哪些数据在每一个链接上所传输的速度。

14. trafshow

与netwatch和pktstat同样,trafshow也能够报告当前活动链接、它们使用的协议以及每条链接上的数据传输速度。它能使用pcap类型过滤器,对链接进行过滤。

只监控TCP链接

15. netload

netload命令只显示关于当前流量负载的一份简短报告,并显示自程序启动以来所传输的总字节量。没有更多的功能特性。它是netdiag的一部分。

16. ifstat

ifstat可以以批处理式模式显示网络带宽。输出采用的一种格式便于用户使用其余程序或实用工具来记入日志和分析。

安装ifstat:Ubuntu、Debian和Fedora用户在默认软件库里面就有它。CentOS用户则须要从Repoforge得到它,由于Epel里面没有它。

17. dstat

dstat是一款用途普遍的工具(用python语言编写),它能够监控系统的不一样统计信息,并使用批处理模式来报告,或者将相关数据记入到CSV或相似的文件。这个例子显示了如何使用dstat来报告网络带宽。

安装dstat

18. collectl

collectl以一种相似dstat的格式报告系统的统计信息;与dstat同样,它也收集关于系统不一样资源(如处理器、内存和网络等)的统计信息。这里给出的一个简单例子显示了如何使用collectl来报告网络使用/带宽。

结束语:上述几个使用方便的命令能够迅速检查Linux服务器上的网络带宽使用状况。不过,这些命令须要用户经过SSH登陆到远程服务器。另外,基于Web的监控工具也能够用来实现一样的任务。

ntop和darkstat是面向Linux系统的其中两个基本的基于Web的网络监控工具。除此以外还有企业级监控工具,好比nagios,它们提供了一批功能特性,不只仅能够监控服务器,还能监控整个基础设施。

—写文不易,你的点赞与转发就是对我最大的支持—

相关文章
相关标签/搜索