如图!求udp 丢包解决方案案玩游戏就丢包!宽带正常求怎么排查

服务端发送的数据是5*256个char数据,在编写服务端的时候,我把缓存区设置为char [2000];然后打印每次收到的数据。然后发现有丢包现象。后来经指导。讲缓存区改大了。问题就解决了。


在编写服务端的时候,我把缓存区设置为char [2000];用来接收服务端发送过来的数据。服务端

在编写服务端的时候,我把缓存区设置为char [2000];用来接收服务端发送过来的数据。服务端

使用高速通道打通同一个地域(Region)下的两台 VPC 网络类型的 实例后,通过 iPerf 测试两台实例内网之间 UDP 丢包率,测试达到 50 Mbps 以上时出现了丢包现象,且随着带宽的增加,丢包率出现增长趋势。如下图:

数据封包,则网络类型的 ECS 实例 A 与实例 B 通信链路图如下:

我们需要对其链路进行排查分析,找出丢包的最终原因。

注意:由于只看到了源 Netcat (即 NC 1) 和目的 Netcat (即 NC 2) 之前的通信,抓包排查要避免误区,即随意判断是 Netcat (NC) 之间的直接通信丢包。

  1. 排查时会发现源端 eth0 的抓包发给了 VGW,但是在目的端抓包发现外壳封装了目的 NC 2 IP,如示例:
  • 确认数据包通过 VGW 后,开始统计抓包信息:
  • 调整后测试 UDP 丢包情况。

测试系统在Linux上的性能发现丢包率极为严重,发210000条数据,丢包达110000之巨,丢包率超过50%。同等情形下Windows上测试,仅丢几条数据。形势严峻,必须解决。考虑可能是因为协议栈Buffer太低所致,于是先看看默认情况:

修改吧,变大一点,变成10M,然后reboot(应该重启某个服务即可)

发现数据在网卡就丢了,判断可能是防火墙引起的,于是执行命令:

证明iptables启动,于是停止防火墙:

这个命令即时生效,开启防火墙的命令:

如果要彻底关闭防火墙,则需要重启后生效

在开启了防火墙时,做如下设置,开启相关端口,

重新测试,没丢一条数据。

linux 内核参数调整说明

所有的TCP/IP调优参数都位于/proc/sys/net/目录。例如, 下面是最重要的一些调优参数, 后面是它们的含义:

/proc目录下的所有内容都是临时性的, 所以重启动系统后任何修改都会丢失。

建议在系统启动时自动修改TCP/IP参数:

把下面代码增加到/etc/rc.local文件, 然后保存文件, 系统重新引导的时候会自动修改下面的TCP/IP参数:

TCP/IP参数都是自解释的, TCP窗口大小设置为256960, 禁止TCP的时间戳(取消在每个数据包的头中增加12字节), 支持更大的TCP窗口和TCP有选择的应答。

上面数值的设定是根据互连网连接和最大带宽/延迟率来决定。

注: 上面实例中的数值可以实际应用, 但它只包含了一部分参数。

另外一个方法: 使用 /etc/sysctl.conf 在系统启动时把参数配置成您所设置的值:

设置Linux内核参数

这里,对每个参数值做个简要的解释和说明。

    (1)shmmax:该参数定义了共享内存段的最大尺寸(以字节为单位)。缺省为32M,对于oracle来说,该缺省值太低了,通常将其设置为2G。

    (2)shmmni:这个内核参数用于设置系统范围内共享内存段的最大数量。该参数的默认值是 4096 。通常不需要更改。

    (3)shmall:该参数表示系统一次可以使用的共享内存总量(以页为单位)。缺省值就是2097152,通常不需要修改。

    (5)file-max:该参数表示文件句柄的最大数量。文件句柄设置表示在linux系统中可以打开的文件数量。

    修改好内核以后,执行下面的命令使新的配置生效。

以 root 用户身份运行以下命令来验证您的设置:

如果系统的参数设置的比上述参数值小,则编辑 /etc/sysctl.conf 文件,添加或更改这些参数。完成后,运行以下命令激活更改:

PS:通常用默认参数就可以了吧.

我要回帖

更多关于 udp 丢包解决方案 的文章

 

随机推荐