gpt4 book ai didi

websocket - jetty websocket 读取超时

转载 作者:行者123 更新时间:2023-12-04 21:15:58 30 4
gpt4 key购买 nike

我正在尝试设置 websocket 客户端/服务器。
问题是由于 session 中的不活动而出现的,在大约 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 设置为更大的值,即使在 session 建立之后,我也会检查它:
client.setMaxIdleTimeout(0);

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

最佳答案

这个问题已经有 2 年了,但仍然存在。原因是 Jetty 默认 websocket 超时为 5 分钟(参见 org.eclipse.jetty.websocket.api.WebSocketPolicy),而在 Tomcat 上为 0。

要修复它,在您的 WebSocket 客户端代码中,您可以执行以下操作:

 WebSocketContainer container = ContainerProvider.getWebSocketContainer();
Session session = container.connectToServer(this, endpointURI);
session.setMaxIdleTimeout(0);
  • 使用 Jetty 9.3.9.v20160517 和 Tomcat 8+ 进行测试 - 问题停止出现在 Jetty 中,而 Tomcat 的行为相同。

  • 但是,实现 @OnError 可能是个好主意。做 session.close()并再次连接以保持连接稳定。另外,Jetty 的 WebSocketTimeoutException派生自 RuntimeException,您可以检查 Throwable 实例并仅在 RuntimeExceptions 上重新连接。对于服务器关闭等情况的“真正”错误处理应该在 container.connectToServer() 的 IOException 处理中。

    关于websocket - jetty websocket 读取超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23622565/

    30 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com