【发布时间】:2016-03-13 08:43:46
【问题描述】:
我们为客户构建了一个使用 Tomcat 8.0.29 的 HTML5 websocket 应用程序。 如果我们从我们的网络或家庭网络启动应用程序,一切正常。但是如果客户从他的网络启动应用程序,一段时间后 websocket 会因错误而停止。这可能会在 5 或 20 分钟后发生。
我们已经在使用和不使用 SSL 的情况下以及在两台不同的服务器上对其进行了测试。只有在客户网络中,连接会因错误而中断。
我们还使用 Tomcat 中包含的 websocket echo 示例 进行测试。和我们的 websocket 一样。一段时间后,websocket 停止并出现错误。但前提是我们从客户网络启动应用程序。
当 echo 示例因错误而停止时,将在 server.log 中写入以下消息
08-Dec-2015 10:20:37.757 SEVERE [http-apr-8081-exec-2] org.apache.tomcat.websocket.pojo.PojoEndpointBase.onError No error handling configured for [websocket.echo.EchoAnnotation] and the following error occurred
java.io.IOException: Unexpected error [730,054] reading data from the APR/native socket [1,639,490,672] with wrapper [org.apache.tomcat.util.net.AprEndpoint$AprSocketWrapper@231e01e4:1639490672].<br/>
at org.apache.coyote.http11.upgrade.AprServletInputStream.doRead(AprServletInputStream.java:133)<br/>
at org.apache.coyote.http11.upgrade.AbstractServletInputStream.read(AbstractServletInputStream.java:124)<br/>
at org.apache.tomcat.websocket.server.WsFrameServer.onDataAvailable(WsFrameServer.java:51)<br/>
at org.apache.tomcat.websocket.server.WsHttpUpgradeHandler$WsReadListener.onDataAvailable(WsHttpUpgradeHandler.java:183)<br/>
at org.apache.coyote.http11.upgrade.AbstractServletInputStream.onDataAvailable(AbstractServletInputStream.java:198)<br/>
at org.apache.coyote.http11.upgrade.AbstractProcessor.upgradeDispatch(AbstractProcessor.java:96)<br/>
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:669)<br/>
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2500)<br/>
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2489)<br/>
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)<br/>
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)<br/>
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)<br/>
at java.lang.Thread.run(Unknown Source)
如果我们在http://www.websocket.org/echo.html 上开始测试,连接将不会关闭并出现错误。
对我来说,这似乎是 Tomcat 的问题。但是我该怎么做才能让它正常运行呢?
Tomcat:8.0.29(也有早期版本)
Windows 7:64 位
协议:HTTP/1.1
【问题讨论】:
-
WebSocket 规范和实现发生了显着变化。使用最新版本的 Tomcat,现在是 8.5.x 系列,对 Tomcat+WebSocket 进行许多改进。也使用最新的网络浏览器。
标签: java tomcat websocket tomcat8 java-websocket