Jetty websocket读取超时

Jetty websocket读取超时,websocket,timeout,jetty,Websocket,Timeout,Jetty,我正在尝试设置websocket客户端/服务器。 该问题是由于会话中的不活动导致的,在约30~60秒的无数据传输后,客户端关闭连接,但以下情况除外: org.eclipse.jetty.websocket.api.WebSocketTimeoutException: Timeout on Read at org.eclipse.jetty.websocket.common.io.AbstractWebSocketConnection.onReadTimeout(AbstractWebSocket

我正在尝试设置websocket客户端/服务器。 该问题是由于会话中的不活动导致的,在约30~60秒的无数据传输后,客户端关闭连接,但以下情况除外:

org.eclipse.jetty.websocket.api.WebSocketTimeoutException: Timeout on Read
at org.eclipse.jetty.websocket.common.io.AbstractWebSocketConnection.onReadTimeout(AbstractWebSocketConnection.java:505)
at org.eclipse.jetty.io.AbstractConnection.onFillInterestedFailed(AbstractConnection.java:258)
at org.eclipse.jetty.websocket.common.io.AbstractWebSocketConnection.onFillInterestedFailed(AbstractWebSocketConnection.java:481)
at org.eclipse.jetty.io.AbstractConnection$ReadCallback.failed(AbstractConnection.java:415)
at org.eclipse.jetty.io.FillInterest.onFail(FillInterest.java:100)
at org.eclipse.jetty.io.AbstractEndPoint.onIdleExpired(AbstractEndPoint.java:146)
at org.eclipse.jetty.io.IdleTimeout.checkIdleTimeout(IdleTimeout.java:153)
at org.eclipse.jetty.io.IdleTimeout$1.run(IdleTimeout.java:50)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
at java.util.concurrent.FutureTask.run(FutureTask.java:166)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:178)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:292)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:722)
ES:套接字关闭:[1001]空闲超时

这没有任何意义,因为我已经在客户端和服务器端尝试将maxIdleTimeout设置为更大的值,即使在会话建立之后,我也会检查它:

client.setMaxIdleTimeout(0);

我尝试了不同的值,而不是上面的“0”,但无效。

此问题已存在2年,但仍然存在。原因是Jetty默认websocket超时为5分钟(请参阅),而在Tomcat上为0

要解决此问题,您可以在WebSocket客户端代码中执行以下操作:

 WebSocketContainer container = ContainerProvider.getWebSocketContainer();
 Session session = container.connectToServer(this, endpointURI);
 session.setMaxIdleTimeout(0);
  • 使用Jetty 9.3.9.v20160517和Tomcat 8+进行测试-当Tomcat表现相同时,问题不再出现在Jetty中
但是,最好实现
@OnError
并执行
session.close()
,然后再次连接以保持连接稳定。另外,Jetty的
WebSocketTimeoutException
是从RuntimeException派生的,您可以检查Throwable的实例,并仅在RuntimeException上重新连接。对于诸如服务器关闭等情况的“真正”错误处理应该在
container.connectToServer()的IOException处理中进行