来源
报错信息:workerman error 2 send buffer full and drop package
定时发送数据的时候,本地偶尔出现这种情况
线上第一条数据发出去就报错了,数据改小一点可以发,不过一会还是会出现这种情况。
解决
根据我的经验,这明显就是缓冲区大小超限了,俗称内存溢出,但是被检测到了。
要想根本上解决这个问题,就要知道workerman的缓冲区的使用规则。
官网上是这样说的,如下图:
听起来是个网络问题,大致意思就是你发的太快或者包太大了,用户还没接收完呢,导致数据还暂时停留在服务器的缓冲区内,并且缓冲区堆积的太多了导致即将要溢出报错了。
那就使用onBufferFull
回调来暂时停止发送数据,等用户接收完再发,但这并不是最优解,因为这种解决方法会导致ping很高,用户与服务器状态的延迟会很高,甚至越来越高,但是不会产生丢包的问题。
所以onBufferFull
应该作为一个解决用户网络不好的情况下使用,最好不要让这个回调触发。
最优解应该是提高服务器网络速度,以及降低发送包的大小,提高频率。
如果对实时有要求,那就适当丢包以保证实时性,如果对内容完整性有要求,那就onBufferFull
回调写好一点,保证每条数据都能接收到。