6

我有一个客户端/服务器设置,其中客户端向服务器发送一条请求消息并返回一堆数据消息。服务器使用 ROUTER 套接字实现,客户端使用 DEALER。通信是异步的。客户端通常是 iPad/iPhone,它们通过 wifi 连接,因此连接不是 100% 可靠的。

我担心的问题是,如果客户端连接到服务器并发送数据请求,但在响应消息被送回之前,通信会中断(例如,超出 wifi 覆盖范围)。

在这种情况下,消息将在服务器端排队等待客户端重新连接。这在短时间内很好,但最终我想删除消息和连接以释放资源。

通过检查活动/超时,服务器和客户端应用程序可以识别连接已消失。客户端可以关闭套接字并以这种方式释放资源,但是如何在服务器中完成呢?

4

2 回答 2

1

根据ZMQ 常见问题解答

如何刷新 ZeroMQ 套接字队列中的所有消息?

没有用于从消息队列中刷新特定消息或所有消息的显式命令。您可以将 ZMQ_LINGER 设置为 0 并关闭套接字以丢弃任何未发送的消息。

根据2013 年的邮件列表讨论

没有选项可以删除旧消息[从传出消息队列]。

您最好的选择是实现心跳,当一个客户端停止响应而没有明确断开连接时,重新启动您的 ROUTER 套接字。凌乱,我知道,这确实是应该与 HWM 配套选择的东西。Pieter Hintjens 显然参与其中(他创建了 ZMQ)——但那是从 2011 年开始的,所以看起来什么都没发生。

于 2015-03-19T13:52:03.413 回答
1

这有点晚了,但是将 tcp keepalive 设置为合理的值会导致死套接字在超时到期后关闭。任何一方都需要心跳来确定另一方仍在响应。我唯一不确定的是如何在不花费所有可用 CPU 处理心跳的情况下为成千上万的客户提供心跳。

于 2017-02-05T22:02:07.470 回答