博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何在Linux下统计高速网络中的流量
阅读量:5862 次
发布时间:2019-06-19

本文共 2208 字,大约阅读时间需要 7 分钟。

nethogs2

在Linux中有很多的流量监控工具,它们可以监控、分类网络流量,以花哨的图形用户界面提供实时流量分析报告。大多数这些工具(例如:, )都是基于 库的 ,这个函数库是用来截取流经网卡的数据包的,可在用户空间用来监视分析网络流量。尽管这些工具功能齐全,然而基于libpcap库的流量监控工具无法处理高速(Gb以上)的网络接口,原因是由于在用户空间做数据包截取的系统开销过高所致。

在本文中我们介绍一种简单的Shell 脚本,它可以监控网络流量而且不依赖于缓慢的libpcap库。这些脚本支持Gb以上规模的高速网络接口,如果你对“汇聚型”的网络流量感兴趣的话,它们可统计每个网络接口上的流量。

脚本主要是基于虚拟文件系统,这是由内核用来将设备或驱动相关的信息输出到用户空间的一种机制。网络接口的相关分析数据会通过“/sys/class/net//statistics”输出。

举个例子,eth0的网口上分析报告会输出到这些文件中:

  • /sys/class/net/eth0/statistics/rx_packets: 收到的数据包数据
  • /sys/class/net/eth0/statistics/tx_packets: 传输的数据包数量
  • /sys/class/net/eth0/statistics/rx_bytes: 接收的字节数
  • /sys/class/net/eth0/statistics/tx_bytes: 传输的字节数
  • /sys/class/net/eth0/statistics/rx_dropped: 当收到包数据包下降的数据量
  • /sys/class/net/eth0/statistics/tx_dropped: 传输包数据包下降的数据量

这些数据会根据内核数据发生变更的时候自动刷新。因此,你可以编写一系列的脚本进行分析并计算流量统计。下面就是这样的脚本(感谢  提供)。第一个脚本是统计每秒数据量,包含接收(RX)或发送(TX)。而后面的则是一个描述网络传输中的接收(RX)发送(TX)带宽。这些脚本中安装不需要任何的工具。

测量网口每秒数据包:

网络带宽测量

下面的屏幕截图显示了上面的两个脚本的输出。

152940zdJ

 原文发布时间为:2014-01-20

本文来自云栖社区合作伙伴“Linux中国”

转载地址:http://hafnx.baihongyu.com/

你可能感兴趣的文章
android event事件录制回放 --1 getevent/sendevent 14-8-9
查看>>
Less学习笔记 -- Nested rules (嵌套规则)
查看>>
解决 - java.lang.OutOfMemoryError: unable to create new native thread
查看>>
移动前端开发之viewport的深入理解
查看>>
vim编辑器相关知识简介
查看>>
Android 输入法键盘和activity页面遮挡问题解决
查看>>
AS3整理的减少CPU消耗的方法
查看>>
雷林鹏分享:PHP EOF(heredoc) 使用说明
查看>>
软工实践第一次作业
查看>>
结对第2次作业——WordCount进阶需求
查看>>
Beta冲刺随笔集
查看>>
ruby
查看>>
Top 50 Most Popular APIs on RapidAPI (2018)
查看>>
如何在Linux用chmod来修改所有子目录中的文件属性?
查看>>
软件模型的优缺点
查看>>
基于hi-nginx的web开发(python篇)——路由装饰器
查看>>
nginx正则笔记
查看>>
windows azure创建同一地缘组和网段的虚拟机
查看>>
获取动态创建的元素触发点击事件
查看>>
在JAVA中利用Jython开发的JUnit测试包相关详细知识讲解
查看>>