Netty返回数据丢包的问题之一

这个问题是在一个群友做压力测试的时候发现的。使用客户端和netty创建一条连接,然后写了一个for循环不停的给服务器发送1500条信息,发现返回只有几百条。另外几百条不知道哪去了。查看代码,发现在服务器发送前做了一个判断:

Netty返回数据丢包的问题之一
 

通过查看源码,问题就在isWriteable()里面,下面看一下源码,在AbstractChannel里面:

Netty返回数据丢包的问题之一
 

再看buf.isWritebale()的实现:文章来源地址https://www.yii666.com/article/756079.html文章来源地址:https://www.yii666.com/article/756079.html

Netty返回数据丢包的问题之一
 

这里有一个变量,控制了是否可以写,那这个变量什么时候发生变化呢,我们接着找,先看看是什么情况下被修改为非0的

Netty返回数据丢包的问题之一
 

这个方法是在这里被调用 的:

Netty返回数据丢包的问题之一
 

这个方法是用来接收发送数据的缓存的,从这里可以看出,当缓存的数据长库大于channel.config.getWriteBufferHighWaterMark()的时候,就不能再写了。这是一种限流 措施,防止数据写入太大,导致消息堆积,内存不足的情况。

我们看到这个值是在channel config中配置的,那么就可以在channel config中修改这个值,

ctx.channel().config().setWriteBufferHighWaterMark(1024*1024 * 8);

也可以在服务启动的时候设置:文章地址https://www.yii666.com/article/756079.html网址:yii666.com<网址:yii666.com

Netty返回数据丢包的问题之一

 给孩子的礼物:


Netty返回数据丢包的问题之一


欢迎加群交流,QQ群:66728073,197321069,398808948 还可以扫描博客左上角二维码,关注游戏技术网公众号

版权声明:本文内容来源于网络,版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。文本页已经标记具体来源原文地址,请点击原文查看来源网址,站内文章以及资源内容站长不承诺其正确性,如侵犯了您的权益,请联系站长如有侵权请联系站长,将立刻删除

Netty返回数据丢包的问题之一-相关文章

  1. [JSON] 前后台如何通过$.ajax()传输JSON数据

  2. Netty返回数据丢包的问题之一

  3. TCP传输协议中如何解决丢包问题

  4. 网络TCp数据的传输设计(黏包处理)

    //1.该片为引用别人的文章:http://www.cnblogs.com/alon/archive/2009/04/16/1437599.html解决TCP网络传输“粘包”问题解决TCP网络传输“粘包”问题作者:杨小平 王胜开原文出处:http://www.ciw.com.cn/ 当前在网络传输应用中,广泛采用的是TCP/IP通信协议及其标准的socket应用开发编程接口(API)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信图片_20190322181744_03.jpg

微信扫一扫打赏

请作者喝杯咖啡吧~

支付宝扫一扫领取红包,优惠每天领

二维码1

zhifubaohongbao.png

二维码2

zhifubaohongbao2.png