java websocket客户端接收数据过大导致断开重连

现象:

项目中需要用到websocket长连接接收服务器推送过来的数据并保存到数据库,刚开始测试时接收服务器少量数据时一切正常,后来测试数据量较大时发现每次在即将接收数据时会掉线,导致数据收不到。

找问题:首先我怀疑是客户端最大接收字节设置得太小,所以在网上找到在web.xml中添加如下配置

  1.   
  2.     org.apache.tomcat.websocket.textBufferSize  
  3.     5242800  
  4.  
    结果还是一样的情况,照常掉线,说明上面配置没有用

    然后通过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的值比初始值大很多。问题解决


    记录自己碰到的问题

 

你可能感兴趣的:(java websocket客户端接收数据过大导致断开重连)