当用此 Web Server 接收 PubSubHubbub Hub Server 发送过来的各类请求时,遇到了一个大问题:google
随着时间推移,处于 ESTABLISHED 状态的 Socket 链接愈来愈多,慢慢抵达500多个,spa
TCP X.X.X.X:8080 72.14.192.68:55693 ESTABLISHED
TCP X.X.X.X:8080 74.125.126.80:59064 ESTABLISHEDcode
最终致使服务爆出异常“too many file descriptors in select”,当此异常发生时,已没法挽救,只能重启服务ip
解决方法
ci
from twisted.protocols.policies import TimeoutMixinget
class TimeoutTester(protocol.Protocol, policies.TimeoutMixin):
conn_timeout = 3
data_timeout = 300
def connectionMade(self):
self.setTimeout(self.conn_timeout)
def dataReceived(self, data):
self.setTimeout(self.data_timeout)
def connectionLost(self, reason=None):
self.setTimeout(None)io