gpt4 book ai didi

android - 为什么 AndroidAsync 断开连接时间这么长?

转载 作者:太空宇宙 更新时间:2023-11-03 11:55:46 27 4
gpt4 key购买 nike

我正在使用 AndroidAsync koush 低级网络协议(protocol)库。我正在使用 WebSocket 连接到服务器。我能够连接、发送/接收消息和断开连接。我的断开连接时间很长。服务器平均 59 秒未检测到断开连接。

为了重现该问题,我连接了 WebSocket,授权并开始每 10 秒执行一次 ping 操作。然后我打开飞行模式,我的网络连接断开了。这时候调用了setClosedCallback方法。以下是我记录此消息的方式:

private WebSocket mConnection;

private WebSocketConnectCallback mSocketCallback = new WebSocketConnectCallback() {
@Override
public void onCompleted(Exception ex, WebSocket webSocket) {
...
webSocket.setClosedCallback(new CompletedCallback() {
@Override
public void onCompleted(Exception ex) {
Log.d("websocket", "WebSocket closed");
if (ex != null && ex.getMessage() != null) {
Log.e("websocket", "WebSocket closed exception: " + ex.getMessage());
}
disconnect();
}
});
}
};

private void disconnect() {
mPingHandler.removeCallbacks(pingRunnable);
if (mConnection != null) {
mConnection.close();
mConnection = null;
}
}

这是让我知道 WebSocket 已关闭的日志消息:

WebSocket 关闭异常:recvfrom 失败:ETIMEDOUT(连接超时)

但是我们的服务器在大约 59 秒内没有收到断开连接消息。我们的服务器正在使用这些库:

  • gevent==1.0
  • gevent-websocket==0.9.2
  • greenlet==0.4.2

有没有办法加快我这边的速度?我可以将某个套接字级别的超时设置为较低的值,以便我的服务器人员更快地收到断开连接消息吗?

最佳答案

因为 AndroidAsync没有实现 closing handshake这是 RFC 6455 所要求的(有关详细信息,请参阅 this),您的 WebSocket 服务器无法检测到断开连接在 WebSocket 的上下文中。因此,服务器必须等待 ETIMEDOUT 在 TCP/IP 的上下文中 以检测断开连接。

使用符合 RFC 6455 并正确实现关闭握手的 WebSocket 库。

关于android - 为什么 AndroidAsync 断开连接时间这么长?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34363183/

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