背景:
之前公司在对接测温门禁设备时。由于设备不支持mqtt,支持websocket 和http 。因为我们的服务器时云服务。将设备接入的系统中只能通过webSocket 。 在对接人员批量上传的时候由于人像是base64字符串类型,所以上传人员的时候数据包有100多kb 。通过websocket 向设备下发时,每次都失败。考虑到是不是数据包的问题,经过设备方答复时每次请求数据包是200KB 那就是数据包在请求报文最大值的范围内。为什么会报错呢?最后与设备方联调的时候是数据包被分成了多个小包发送。导致设备接收数据有问题,导致的失败。
设备方说之前有客户也遇到这个问题,修改了发送数据包大小就解决了。给到了一份文章:
安装上面写的,集成到项目中,再次尝试发现也是没有效果的。百般无奈下,决定追源码,看看springboot 集成的websocket 发送数据包是多大。
在这里可以看到这里有个编辑器缓冲区 encoderBuffer,那这个就是发送数据包的缓冲区。追进去看看它默认大小是多少
解决:
在这里可以看见spring boot 默认的大小为8KB 这个值也太小了,然后继续追源码发现这个值是可以在启动的时候通过参数修改的。
然后在启动jar包的时候将数据包修改为320kb
-Dorg.apache.tomcat.websocket.DEFAULT_BUFFER_SIZE=327680
修改后重新启动。在次调试数据一次性发送成功,没有在分包发送了。问题解决。
总结:
springboot 集成webSocket 时默认发送的数据缓冲区大小为8KB ,如果超过这个大小将会分包发送。
该值可以在启动的时候修改,在启动脚本上加上
-Dorg.apache.tomcat.websocket.DEFAULT_BUFFER_SIZE=你需要的大小。就可以了。