现象:
项目中需要用到websocket长连接接收服务器推送过来的数据并保存到数据库,刚开始测试时接收服务器少量数据时一切正常,后来测试数据量较大时发现每次在即将接收数据时会掉线,导致数据收不到。
找问题:首先我怀疑是客户端最大接收字节设置得太小,所以在网上找到在web.xml中添加如下配置
- <context-param>
- <param-name>org.apache.tomcat.websocket.textBufferSize</param-name>
- <param-value>5242800</param-value>
- </context-param>
结果还是一样的情况,照常掉线,说明上面配置没有用
然后通过wireshark抓包,查找到底是服务器还是客户端主动断开的连接,发现确实是客户端主动断开。
通过spring websocket源码发现在连接成功后会传入一个WebSocketSession
public void afterConnectionEstablished(WebSocketSession session) throws Exception {
this.session = session;
this.session.setTextMessageSizeLimit(TextMessageSizeLimit);
logger.info("connected...........");
sendAliveMsgTime = 0;
receiveAliveMsgTime =0;
super.afterConnectionEstablished(session);
}
WebSocketSession 有一个TextMessageSizeLimit属性(并有一个默认值),于是直接在连接成功后设置TextMessageSizeLimit的值比初始值大很多。问题解决
记录自己碰到的问题