当我运行命令ethtool -S wlp2s0
时,我得到以下信息:
NIC statistics:
rx_packets: 63
rx_bytes: 14163
rx_duplicates: 2
rx_fragments: 58
rx_dropped: 30
tx_packets: 60
tx_bytes: 9668
tx_filtered: 0
tx_retry_failed: 0
tx_retries: 39
sta_state: 4
txrate: 115600000
rxrate: 130000000
signal: 189
channel: 0
(...)
但是,当我转到该/sys/class/net/wlp2s0/statistics
文件夹时,统计信息与 ethtool 不同(它们似乎是 ifconfig 打印的)。例如,当我rx_dropped
从文件夹中显示时,结果总是0
.
这是ifconfig
界面的显示:
wlp2s0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.1.115 netmask 255.255.255.0 broadcast 192.168.1.255
inet6 fe80::6f9d:4eac:5bec:1ea6 prefixlen 64 scopeid 0x20<link>
ether 88:b1:11:6a:1d:82 txqueuelen 1000 (Ethernet)
RX packets 42483 bytes 55964467 (55.9 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 9309 bytes 1393476 (1.3 MB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
我的问题是,如果我想以 1 秒为间隔了解丢弃的数据包,我从哪里可以获得该信息?ethtool
似乎是一个不错的选择,但我不知道它从哪里获取信息,我不明白为什么信息与统计文件夹不同......
另外, rx_dropped 中的 30 值是什么意思?是接口启动后丢弃的数据包吗?
ethtool
使用 ioctl 获取统计信息SIOCETHTOOL
,它接受一个指向struct ethtool_stats
. 要获取统计信息,cmd
结构的字段应该具有 valueETHTOOL_GSTATS
。在调用该 ioctl 之前,您必须使用另一个 ethtool ioctl(也SIOCETHTOOL
可以struct ethtool_sset_info
使用其cmd
字段初始化为ETHTOOL_GSSET_INFO
的指针,或者struct ethtool_drvinfo
其cmd
字段初始化为 的指针ETHTOOL_GDRVINFO
)来了解驱动程序即将返回的不同统计值的数量,所以你可以为struct ethtool_stats
....如果您不使用 C 编程,那么上面非常密集、术语丰富的描述可能对您毫无意义。如果您需要
ethtool
在脚本中访问统计信息,我建议使用具有可用 ethtool 接口绑定的脚本语言,例如 Perl(模块Linux::Ethtool
)或 Python(显然是https://pypi.org/project/netifaces/)。这些应该使访问统计数据更加直接。当然,您始终可以解析
ethtool
命令的输出,但是如果您想每秒轮询一次统计信息,那么每次需要统计信息时消除vfork()
一两个新进程的需要可能是有益的。结果值来自 NIC 驱动程序。驱动程序开发人员还没有添加代码来访问相关统计信息的事实也 via
/sys/class/net/<name>/statistics
或 via/proc/net/dev
whereifconfig
get them from 这表明驱动程序定义这些值的方式可能与/proc/net/dev
和/或/sys/class/net/*/statistics
... 或者它可能只是表明驱动程序不幸的是,实施并不完美。(开发人员可能已经选择首先实现
ethtool
API,因为它是最新的,并且“当我有时间时”使旧的统计接口不完整。另请注意,ifconfig
大多数发行版都弃用了该命令,因为它不是保养得很好。)要了解详细信息,您可能必须阅读实际驱动程序的文档和/或源代码注释。由于您没有指定网卡型号或驱动程序名称,因此没有其他人可以为您完成。的输出对于
ethtool -i wlp2s0
识别 NIC 驱动程序非常有用。