当我运行命令时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 值意味着什么?是不是接口up后丢包了?
答案1
ethtool
使用 ioctl 获取统计信息SIOCETHTOOL
,它采用指向 的指针struct ethtool_stats
。要获取统计信息,cmd
结构体的字段应具有值ETHTOOL_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 驱动程序。事实上,驱动程序开发人员还没有添加代码来访问相关统计数据,也/sys/class/net/<name>/statistics
没有通过从/proc/net/dev
哪里ifconfig
获取它们,这表明驱动程序定义这些值的方式可能与/proc/net/dev
和/或/sys/class/net/*/statistics
...有所不同,或者它可能只是表明驱动程序不幸的是,实施并不完美。
(开发人员可能选择ethtool
首先实现 API,因为它是最新的,并在“有时间时”保留不完整的旧统计接口。另请注意,ifconfig
大多数发行版已弃用该命令,因为它不是保养得很好。)
要了解详细信息,您可能需要阅读实际驱动程序的文档和/或源代码注释。由于您没有指定网卡型号或驱动程序名称,因此没有其他人可以为您做这件事。的输出ethtool -i wlp2s0
对于识别 NIC 驱动程序非常有用。