项目中集成webScoket遇到很多莫名其妙问题,这里记录一下,当前使用的是SSM架构整合的,没有使用SpringBoot;
坑1: WebSocket connection to ‘ws://localhost:8080/ws’ failed: Error during WebSocket handshake: Unexpected response code: 404
前端发起链接ws://XXX/ws 一直报404
前端链接地址:
websocket = new WebSocket("ws://192.168.8.8:8080/项目名/ws");
webscoket 后台链接地址:
registry.addHandler(webSocketHandler, "/ws").addInterceptors(chatHandshakeInterceptor);
解决办法:
原来项目中的springMVC前置控制配置的是*.do ,怪不得一直404 (坑啊)
<servlet> <description>Spring MVC Front controller</description> <display-name>FrontController</display-name> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:cfg/spring-for-webmvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
坑2: Spring webosket 拦截器中获取不到登录session
在登录时明明存入HttpSession 中了,使用其他的控制层中的代码都可以取得,可是在WebScoket中的ServerHttpRequest 就是获取session一直为null,弄得很郁闷;
解决方法:
前端的访问地址是ip地址 如:ws://192.168.8.8/ws ,而浏览器中的访问项目使用的http://localhost/项目 ,
将访问地址改为ip地址即可(这真神坑啊),参考这篇: Spring webosket 握手拦截器中获取不到session
坑3: nginx集群环境WebosketSession丢失(多节点服务器)
前言:
首先我想到了用redis作为中间存储,websocketsession是无法被序列化的,即使被序列化了取出来未必也用得了;
解决方案1:调整nginx的负载方式
调整nginx的负载方式,由原来的“权重”负载改为“ip_hash值”,每个请求按访问ip的hash结果分配,这样能达到用户访问的一直是1台节点服务器,参考:Nginx 负载均衡的几种方式
缺点就是如果你系统只是负责固定区域的用户,或者用户群体是在一个网段,这样负载效果不佳;
解决方案2:使用redis里也有类似的消息队列功能来实现
参考大神这篇:websocket集群开发消息共享方案 http://blog.cxnxs.cn/post/70.html
由于项目时间关系,没有研究方案2,有精力的小伙伴可以研究下,然后反馈下结果,相互探讨下。
有大佬指点或自己的见解可以给我留言哦,o( ̄︶ ̄)o
原文链接:https://blog.csdn.net/qq_36698956/article/details/94359242
原创文章,作者:优速盾-小U,如若转载,请注明出处:https://www.cdnb.net/bbs/archives/5740