0

0

Linux 网络延迟高的可能原因

冷炫風刃

冷炫風刃

发布时间:2026-01-23 20:19:33

|

989人浏览过

|

来源于php中文网

原创

网卡驱动或固件过旧、网络栈参数配置不当、ARP冲突或广播风暴、容器/虚拟化转发跳数过多是导致延迟抖动的四大主因,需分别通过ethtool、sysctl、tcpdump、perf等工具定位并优化。

linux 网络延迟高的可能原因

网卡驱动或固件过旧导致延迟抖动

老旧驱动常无法正确处理高吞吐下的中断合并、RSS 队列分配或TSO/GSO卸载,引发软中断堆积和延迟突增。特别是某些 Realtek、Intel I210 或 Broadcom BCM57xx 网卡在内核 5.4 之前版本中存在已知的 tx_timeout 延迟问题。

实操建议:

  • 运行 ethtool -i eth0 查看驱动名与版本,比对厂商官网最新固件;
  • 升级前先用 ethtool -K eth0 gso off tso off 临时关闭卸载功能,观察延迟是否收敛;
  • 若使用 Intel 网卡,确认是否启用了 irqbalance,并检查 /proc/interrupts 中对应网卡 IRQ 是否集中在单个 CPU 核上。

网络参数配置不当放大 RTT 波动

默认 TCP 参数在高延迟或高丢包链路下容易触发重传退避、窗口收缩,表现为 ping 延迟忽高忽低,tcpping 显示超时率上升。典型诱因包括过小的 net.ipv4.tcp_rmem 缓冲区、未启用 tcp_slow_start_after_idle 关闭、或 net.core.netdev_max_backlog 过低导致队列溢出丢包。

实操建议:

  • ss -i 观察连接的 cwndrttvar,若 rttvar 持续 >100ms,说明 RTT 估计不稳定;
  • 临时调大接收缓冲:执行 sysctl -w net.ipv4.tcp_rmem="4096 65536 8388608"
  • 禁用空闲后慢启动(避免突发流量被限速):sysctl -w net.ipv4.tcp_slow_start_after_idle=0
  • 检查 net.core.netdev_max_backlog 是否小于当前接口 PPS,可设为 5000 或更高。

同一物理网段存在 ARP 冲突或广播风暴

局域网内异常设备持续发送伪造 ARP 响应、DHCP 请求泛洪或生成树协议(STP)震荡,会导致主机频繁刷新 arp -a 表项、触发 gratuitous ARP,并使内核 neighbour 子系统陷入高频垃圾回收,间接拖慢 IP 层转发路径。

PHPB2B
PHPB2B

PHP-B2B(原友邻b2b)是一套能够帮助用户,快速建立高效、多功能电子商务网站的php应用程序,本程序采用目前互联网上最流行的LAMP组合(Linux+Apache+Mysql+PHP)开发完成,同时利用Smarty模板技术实现了网站前台与后台的有效分离,用户可以快速地在此基础上开发自己的模板。 友邻php提供了电子商务应用最常见求购、供应、商品、公司库等模块,同时为企业用户提供了一个发布信

下载

实操建议:

  • tcpdump -i eth0 arp or broadcast 抓包,过滤出异常源 MAC 的 ARP 流量;
  • 检查 /proc/net/neigh/eth0/statsfailedunresolv 计数是否持续增长;
  • 临时锁定关键网关 ARP 条目:ip neigh replace 192.168.1.1 lladdr 00:11:22:33:44:55 dev eth0 nud permanent
  • 若交换机可控,开启 DHCP Snooping 和 ARP Inspection 功能。

容器或虚拟化环境引入额外转发跳数

使用 Docker 默认桥接模式、Kubernetes Calico/Flannel 或 KVM 的 virtio-net + iptables 规则链时,每个数据包可能经历多次 netfilter hook(如 FORWARDPOSTROUTING),尤其当启用 conntrack 且连接数超限时,nf_conntrack 查找会成为瓶颈,表现为延迟毛刺与 dmesg 中大量 "nf_conntrack: table full" 日志。

实操建议:

  • perf record -e 'net:*' -a sleep 10 采样,查看是否大量命中 nf_hook_slow
  • 检查 conntrack 使用量:conntrack -S,若 entries 接近 max,需调大 net.netfilter.nf_conntrack_max
  • 对非必要服务禁用 conntrack:iptables -t raw -A PREROUTING -p tcp --dport 8080 -j NOTRACK
  • 容器场景优先选用 hostNetwork 或 CNI 插件的 eBPF 模式(如 Cilium),绕过 iptables 路径。
真实环境中,延迟高往往不是单一原因,而是驱动缺陷叠加 conntrack 拥塞再遇上 ARP 异常的组合。最易被忽略的是:你以为在测“网络”,其实瓶颈在内核协议栈某处锁竞争(比如 __nf_ct_lookup 持有 nf_conntrack_lock)或网卡 ring buffer 溢出后丢弃了 ACK 包——这时 ping 看似正常,但应用层 TCP 吞吐已断崖下跌。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1051

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

107

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

593

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

11

2026.01.19

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号