局域网UDP丢包优化

2 篇文章 0 订阅

之前一直没考虑清楚为何接收到UDP数据丢包的问题,当意识到这造成很大问题时便狂查资料,有以下结论:

1.发送方发送的数据太快,导致UDP输入队列溢出(系统会丢掉一些包),在应用程序看来是即是丢包。

解决方法:

1.想办法提高应用程序对UDP包的处理速度。

2.提高UDP输入队列缓冲区大小,可通过setsockopt的SO_RCVBUF来进行设置,但是这里的设置还受限于系统的设置,

在linux系统下可以通过设置系统最大缓冲区来设定:

        在 /etc/sysctl.conf 中加入

net.core.rmem_max = 131071 //最大值,有资料说甚至可以设置为10M或更大

net.core.rmem_default = 112640//默认值


设置后重启可通过:sysctl -a |grep net.core 查看

论证例子:

题: buf = x; 接收速度,奇数秒:y byte/s。偶数秒:0byte/s;处理速度:z byte/s;问buf 多久会满?

解: (1).当x<=y-z时,第一秒就会满。

(2)当x>y-z时,x = (y/2 - z)*t.得出t = (2*x)/(y-2*z).

2.1 当 y < 2*z时,t无大于0的解。(即buf永远不会满)

2.2 当y>2*z时, t = (2*x)/(y-2*z).

若要使buf永远不满:

(1)的解决办法为,增大x,z。减小y.

(2.2)的解决办法是减小y,还有增大z。

无论如何,最终要使数据满足2.1的情况。

由此得出结论,首先满足基本条件即不可以让第一次发送的高峰期就将缓冲区填满,降低发送方的发送速度,加快处理速度均会使缓冲区达到不满的状态。

一个线程接收,一个线程处理并不会提高处理速度,只是变相的增大了缓冲区大小,将系统缓冲区转移到了自己的缓冲区。

2.当然最愚蠢的错误就是将recvfrom中的buf_size设置小了。

3.局域网里丢包率也是很小的,并且未经过路由器,不会乱序,如果在到达网卡之前就丢包了,那就要检查网络状况,当然也可以通过ethtool设置网卡信息提高接收成功率。网上还有提到NAPI可以提高网卡处理效率,通过使用轮询降低中断次数。


参考资料:

TCP/IP详解(协议卷)

linux性能调优

http://www.stamhe.com/?p=270

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: TCP通信在局域网环境下丢包可能有以下几个原因: 1. 网络拥塞:如果局域网中的网络流量过大,可能导致数据包丢失。可以通过增加网络带宽或者优化网络拓扑结构来缓解拥塞问题。 2. 网络延迟:如果数据包在传输时遇到网络延迟,可能导致数据包丢失。可以优化网络设备的配置来缩短网络延迟。 3. 硬件问题:局域网中的网络设备(如交换机、路由器等)可能存在硬件问题,导致数据包丢失。可以检查设备是否正常工作,或者更换设备。 4. 程序问题:程序本身可能存在漏洞或者逻辑错误,导致数据包丢失。可以通过检查程序代码来排查问题。 针对丢包问题,可以通过以下方式进行优化: 1. 使用可靠的传输协议:TCP是一种可靠的传输协议,可以保证数据传输的可靠性和完整性。可以通过使用TCP协议来避免丢包问题。 2. 增加重传机制:在通信过程中,可以增加重传机制,当发现数据包丢失时,及时重传数据包,保证数据的完整性。 3. 优化程序设计:在程序设计过程中,可以考虑数据包大小、发送频率等因素,避免数据包丢失。同时,可以增加数据校验机制,保证数据的完整性。 ### 回答2: Qt是一个跨平台的应用程序开发框架,其中包含了TCP通信的功能,可以用于在局域网内进行数据传输。丢包问题是指在通信过程中,部分数据包无法正常传输到目标主机的现象。 局域网丢包问题的解决可以从以下几个方面来考虑: 1. 检查网络环境:首先,需要检查局域网的网络环境是否稳定。可能是由于网络延迟、带宽限制或者网络拥堵等原因导致数据包丢失。可以尝试进行网络优化,例如调整网络带宽、增加网络缓冲区大小等方式来改善网络环境。 2. 优化代码逻辑:在进行TCP通信时,需要合理地编写代码逻辑,确保数据包的稳定传输。可以通过添加重传机制、数据校验等方式来提高通信的可靠性。同时,也要合理地设置缓冲区大小,防止数据包溢出或者缓存积压导致丢包。 3. 异常处理机制:考虑到网络通信的不确定性,需要在代码中添加异常处理机制,及时捕获并处理异常情况,避免程序崩溃或者数据丢失。可以使用Qt提供的信号槽机制来实现异常处理,例如捕获网络错误信号并进行相应处理。 4. 数据分包处理:如果遇到较大的数据传输,可以将数据分包发送,以减少数据包的丢失概率。可以将大块数据按照固定大小进行切割,并添加相关的标记进行拼接。在接收端接收到所有数据包后,再进行拼装。 总结来说,局域网丢包问题在Qt的TCP通信中是常见的,可以通过检查网络环境、优化代码逻辑、添加异常处理机制以及数据分包处理来解决。 ### 回答3: Qt是一种跨平台的C++应用程序开发框架,它提供了丰富的库和工具,方便开发人员进行图形界面和网络通信的实现。 在使用Qt进行tcp通信时,有时候会遇到局域网丢包的问题。丢包通常是由网络环境不稳定、网络拥塞或其他因素引起的。 为了解决局域网丢包问题,可以尝试以下方法: 1. 检查网络环境:确保局域网连接稳定,并且没有其他设备在占用过多带宽。 2. 设置超时时间:在Qt中,可以为tcp连接设置超时时间,如果在指定时间内没有收到响应,可以进行重试或其他处理。 3. 使用可靠的传输协议:如果对数据的可靠性要求较高,可以考虑使用可靠的传输协议,如TCP协议。 4. 重新建立连接:如果发现连接丢失或者数据丢失,可以尝试重新建立连接,或者通过心跳包等机制检测连接状态。 5. 错误处理和重试机制:在代码中添加适当的错误处理和重试机制,当发现丢包时,可以重试发送丢失的数据。 6. 数据校验和重传:在发送数据时可以附加校验和,接收端在接收数据后校验数据的完整性,并进行重传,以确保数据的准确传输。 总之,解决Qt tcp通信局域网丢包问题需要综合考虑网络环境、传输协议、错误处理和重试机制等多个方面。通过合理的设置和处理,可以提高局域网通信的可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值