由于某种原因,ip -s link
显示的数字与不同/proc/net/dev
,特别是超限计数。
对于给定的接口,ip 没有显示溢出数据包:
$ ip -s link show eth-ext1
7: eth-ext1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 1000
link/ether 00:08:a2:0d:00:74 brd ff:ff:ff:ff:ff:ff
RX: bytes packets errors dropped overrun mcast
1038103044434 1099087192 0 0 0 401298
TX: bytes packets errors dropped carrier collsns
543051882227 844808055 0 0 0 0
虽然proc
我们看到了非零的溢出(这是我假设fifo
所指的):
$ cat /proc/net/dev
Inter-| Receive | Transmit
face |bytes packets errs drop fifo frame compressed multicast|bytes packets errs drop fifo colls carrier compressed
[...]
eth-ext1: 1038106099296 1099090833 0 0 467554 0 0 401301 543052535442 844810749 0 0 0 0 0 0
我倾向于相信接口上确实存在超限数据包,因此输出似乎ip link
不正确。我遗漏了什么吗?
答案1
fifo 和 overrun 不一样。只需输入 ip -s -sa,就会出现类似这样的信息
RX: bytes packets errors dropped overrun mcast
53152 864 0 0 0 0
RX errors: length crc frame fifo missed
0 0 0 0 0
TX: bytes packets errors dropped carrier collsns
53152 864 0 0 0 0
TX errors: aborted fifo window heartbeat transns
0 0 0 0 0
超限 — 导致数据包丢失的接收器超限总数。一般来说,如果接口超限,则意味着内核存在严重问题,或者您的计算机对于此接口来说太慢。
fifo(文件输入文件输出)错误