websocket推送消息异常(连接意外断开)解决方法

最近项目在现场部署运行过程中,出现websock不可用的情况,提交请求后无返回结果的响应。

大部分项目现场运行正常。在部分项目现场出现异常的情况。

开始阶段排查业务代码,加上只是部分现场出现异常的情况,分析,环境的问题应该大于代码的问题。

在网上查找,Websock 异常一般有这么几种情况:

  1. websock监听端口冲突或被防火墙拦截。
  2. tomcat下面的catalina.jar 以及websock-api.jar 与项目中导入的重复的jar冲突。
  3. 部署环境使用了nigix ,需要进行配置。
  4. sevlet版本问题,需要修改web.xml。
  5. 网络原因导致连接超时。最常见的情况!!!

而,经过分析后得出我这个问题便是网络不稳定造成的,因连接超时引起的。

运行环境centos7.5 jdk1.8 tomcat7

log文件打印报错信息如下。

websocket推送消息异常(连接意外断开)解决方法_第1张图片

这种错误需要修改两个地方。

1、是把超时时间设定的大一点。2、是像报错信息中说的一样,修改web.xml文件,使他支持异步。在sevlet和filter下面添加true 这句代码。

修改超时时间的设置,即sockjs-0.3.min.js中的rtt时间。具体版本因自己的项目而定。

websocket推送消息异常(连接意外断开)解决方法_第2张图片

 

web.xml中修改如下

websocket推送消息异常(连接意外断开)解决方法_第3张图片

在filter中的添加位置要留意。多个filter以及sevlet的情况,添加要根据自己工程的具体情况而定。每个sevlet及filter上添加也是不可以的!在我的项目中只添加在了struts2配置以及appsevlet配置这两个下面。

websocket推送消息异常(连接意外断开)解决方法_第4张图片

参考文档

https://www.cnblogs.com/guangshan/p/4916993.html

https://www.cnblogs.com/zuochanzi/p/9755486.html

你可能感兴趣的:(java开发)