linux系统内核UDP丢包原因分析
linux系统内核UDP丢包原因分析
1、UDP校验和错误
现象:可以用netstat -su 查看到有UDP错包。
tcpdump捕包,在wireshark打开捕获的udp报文,开启校验和选项,有错包。
方案:查找链路故障 www.ahlinux.com
2、防火墙开启
现象:特定端口的包收不到
方案:使用service iptables stop关闭。
3、rp_filter开启
现象:tcpdump有包,协议栈收不到。某个地址发送的包一个包都收不到,而另一地只发过来的没问题。
方案:将/etc/sysctl.conf中rp_filter设为0。
参见:http://serverfault.com/questions/163244/linux-kernel-not-passing-through-multicast-udp-packets
校验包的源地址与其网卡地址的开关,防止IP欺骗,linux 2.6.32默认开启。
4、应用程序性能问题,缓冲区满。
现象:应用断断续续能收到UDP包。
方案:使用vmstat和top命令发现cpu或IO过载。增大缓冲区,优化程序。
- 本文来自:Linux教程网
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。