我有一个当前执行以下操作的客户:
- 连接
- 在本地收集一些数据
- 将该数据发送到服务器
- 重复
- 如果断开连接,则重新连接并继续上述操作(未显示)
像这样:
def do_send(self):
def get_data():
# do something
return data
def send_data(data)
self.sendMessage(data)
return deferToThread(get_data).addCallback(send_data)
def connectionMade(self):
WebSocketClientProtocol.connectionMade(self)
self.sender = task.LoopingCall(self.do_send)
self.sender.start(60)
但是,当断开连接时,我希望继续收集数据,可能会在一定限制下排队和写入文件。我已经查看了似乎是我需要的 DeferredQueue 对象,但我似乎无法破解它。
在伪代码中,它会是这样的:
queue = DeferredQueue
# in a separate class from the client protocol
def start_data_collection():
self.collecter = task.LoopingCall(self.get_data)
self.sender.start(60)
def get_data()
# do something
queue.put(data)
然后让客户端协议检查队列,这是我迷路的地方。DeferredQueue 是我需要的,还是有更好的方法?