The remote endpoint was in state [TEXT_FULL_WRITING]

使用websocket出现的坑

The remote endpoint was in state [TEXT_FULL_WRITING] which is an invalid state for called method

 

      websocket推送数据的方法有:

               session.getBasicRemote().sendText(message);  //同步发送

               session.getAsyncRemote().sendText(message); //异步发送

经过测试,在高并发的情况下,两种发送方法都会抛出上面的异常。查了很多博客,发现是多个线程同时使用同一session发送的原因。决定做如下修改。

synchronized(session){

    session.getAsyncRemote().sendText(message);

}

经测试异步发送还是会抛出上述异常,同步不会出现。猜想:异步应该是new一个线程去发送,即使使用synchronized同样会出现两个session同时被不同的线程操作的时机。

 

决定使用:

 

synchronized(session){

    session.getBasicRemote().sendText(message);

}

//在网络非常好的情况下。多线程同一个session发送数据

150ms/条的情况下没有出现上述异常

 

建议:上述发送方式虽然不会抛出上述异常,建议在并发量非常高的情况下,尽量单个sesson创建线程去发送。因为在循环session群发的时候,一个session回话网络不好,会出现超时异常,当前线程会因此中断。导致后面的session没有进行发送操作。使用单个线程,单个session情况下避免session之间的相互影响。具体超时异常如下:

java.util.concurrent.TimeoutException: null
        at java.util.concurrent.FutureTask.get(FutureTask.java:205)
        at com.icancontrol.meter.controller.ListMapWebSocket.execute(ListMapWebSocket.java:241)
        at com.icancontrol.meter.controller.ListMapWebSocket.sendMessage(ListMapWebSocket.java:187)
        at com.icancontrol.meter.common.thread.SendThread.run(SendThread.java:40)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
        at java.lang.Thread.run(Thread.java:745)

 

  • 17
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值