登录
首页 >  文章 >  linux

Linux怎么查看网卡的环形缓冲区大小 Linux网络丢包调优详解

时间:2026-05-04 22:33:00 423浏览 收藏

golang学习网今天将给大家带来《Linux怎么查看网卡的环形缓冲区大小 Linux网络丢包调优详解》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习文章或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮助到大家!

直接运行ethtool -g eth0,输出中“Current hardware settings”下的RX值即当前RX Ring Buffer大小;需结合ethtool -S eth0 | grep rx_missed_errors确认是否溢出,并联动调大net.core.netdev_max_backlog等内核参数。

Linux怎么查看网卡的环形缓冲区大小 Linux网络丢包调优详解

怎么用 ethtool 查看当前 RX Ring Buffer 大小

直接运行 ethtool -g eth0,输出里 “Current hardware settings” 下的 RX 值就是当前生效的环形缓冲区深度。注意:不同网卡驱动默认值差异很大——ixgbe 通常默认 512,igb 默认 256,而某些虚拟网卡(如 veth)不支持该参数,执行会报错 Operation not supported

常见误判点:

  • 别只看 ifconfigip -s linkoverruns,它反映的是 DMA 写入失败次数,但无法区分是 Ring Buffer 溢出还是 SKB 分配失败
  • ethtool -g 显示的 Maximum 不代表一定能设到那么大,需查对应驱动文档(比如 Intel X710 卡最大支持 4096,但部分固件版本限制为 2048)

rx_missed_errors 非零说明 Ring Buffer 真的不够用了

ethtool -S eth0 | grep rx_missed_errors 返回值持续上涨,基本可断定是 Ring Buffer 溢出:网卡 DMA 把包写进缓冲区时,驱动还没来得及取走旧数据,新包就被丢弃。这不是内核协议栈的问题,而是硬件和驱动协同层面的瓶颈。

此时调大 rx 值是最直接有效的手段,但要注意:

  • 增大后必须配合 net.core.netdev_max_backlog(建议 ≥ Ring Buffer 大小),否则内核软中断队列会成为新瓶颈
  • 不要盲目设到最大值——过大的 Ring Buffer 会增加 CPU cache miss 和延迟抖动,对低延迟场景反而有害
  • 观察 cat /proc/interrupts | grep eth0 中对应 CPU 核的软中断计数,若某核长期占 90%+,说明单核处理不过来,需配合 RSS 队列或 RPS 分流

为什么调了 ethtool -G 还是丢包?关键在内核缓冲区联动

Ring Buffer 只管“网卡到内核”的一跳,后面还有两道关卡:内核 UDP 套接字接收队列(sk_receive_queue)和应用层 recvfrom 调用频率。若 netstat -s | grep UdpOverflows 在涨,说明套接字队列满了,和 Ring Buffer 无关。

必须同步做三件事:

  • 调大全局上限:sysctl -w net.core.rmem_max=26214400(25MB)
  • 应用启动时显式设置:setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &size, sizeof(size)),size 至少 4MB
  • 确认 net.core.rmem_default 不拖后腿(建议设为 4MB,避免新 socket 继承过小默认值)

漏掉任意一项,Ring Buffer 再大也没用——包会在内核协议栈里被 UdpOverflows 丢掉。

永久生效要绕开 NetworkManager 和 systemd-networkd 的坑

ethtool -G eth0 rx 4096 是临时命令,重启即失效。但直接写进 /etc/rc.local 很可能失败:现代发行版中网卡往往在 rc.local 执行前就已初始化完毕,命令无效。

可靠做法分情况:

  • 使用 systemd:写一个 /etc/systemd/system/ethtool-eth0.serviceAfter=systemd-udev-settle.service,并在 ExecStart 中加 sleep 1 && ethtool -G eth0 rx 4096
  • RHEL/CentOS 8+:在 /etc/sysconfig/network-scripts/ifcfg-eth0POST_UP_CMD="ethtool -G eth0 rx 4096"
  • Debian/Ubuntu:用 /etc/network/if-up.d/ethtool-tune 脚本,开头加 [ "$IFACE" = "eth0" ] || exit 0

最易被忽略的是:某些云厂商镜像(如 AWS AL2、Azure Ubuntu)默认禁用 rc-local 服务且屏蔽 if-up.d,必须先 systemctl enable rc-local 或改用 udev 规则。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>