扭曲-检测丢失的连接需要30多分钟

twisted - detection of lost connection takes more than 30 minutes(扭曲-检测丢失的连接需要30多分钟)
本文介绍了扭曲-检测丢失的连接需要30多分钟的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我已经用python编写了一个tcp客户端,它连接到服务器并使用简单的基于字符串的协议(由服务器制造商定义)进行通信。应保持TCP/IP连接,并在出现故障时重新连接。

当发生某种网络错误时(我假设是在服务器端或在沿途的某个节点上),客户端需要很长时间才能意识到这一点并启动新连接,而不是几分钟。

有没有办法加快这一速度?某种内置的TCP/IP保持活动功能,可以更快地检测到断开?

我可以自己实现一个Keep Alive机制,并查找超时,但我不确定这是否是本例中的最佳实践。你认为如何?另外,将reactor.connectTCP()reactor.run()ClientFactory一起使用时,强制重新连接的最佳方式是什么?

tcp

基于推荐答案的协议的应用程序级保持活动是一个好主意。您可能应该实现这一点。这使您可以完全、准确地控制您希望从应用程序获得的超时语义。

tcp本身具有保活机制。您可以通过您的协议中的ITCPTransport方法调用来启用此功能。例如:

class YourProtocol(Protocol):
    def connectionMade(self):
        self.transport.setTcpKeepAlive(True)
该保持连接的确切语义依赖于平台和配置。这是完全有可能的,这是已经启用,并是检测您的连接丢失。对于此机制来说,30分钟是一个相当合理的时间来通知丢失的连接。

这篇关于扭曲-检测丢失的连接需要30多分钟的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)