连接失败后,Twisted deferred 不可调用
我这里有一个客户端工厂:
import logging, traceback
from twisted.internet.protocol import ClientFactory
from twisted.internet import defer, reactor, ssl
from twisted.application import service
from protocols.smpp.protocol import SMPPClientProtocol
class SMPPClientFactory(ClientFactory):
protocol = SMPPClientProtocol
def __init__(self, config):
self.config = config
def getConfig(self):
return self.config
def clientConnectionFailed(self, connector, reason):
print "clientConnectionFailed"
self.connectDeferred.errback(reason)
def clientConnectionLost(self, connector, reason):
print "clientConnectionLost"
def connect(self):
self.connectDeferred = defer.Deferred()
factory = SMPPClientFactory(self.config, self.msgHandler)
self.log.warning('Establishing TCP connection to %s:%d' % (self.config.host, self.config.port))
reactor.connectTCP(self.config.host, self.config.port, factory)
return self.connectDeferred
然后它在这里启动代码:
import logging, traceback
from twisted.internet import reactor, defer
from protocols.smpp.configs import SMPPClientConfig
from protocols.smpp.smpp_operations import SMPPOperationFactory
from testbed.client import SMPPClientFactory
class SMPP(object):
def __init__(self, config=None):
if config is None:
config = SMPPClientConfig()
self.config = config
self.opFactory = SMPPOperationFactory(config)
def run(self):
try:
#Bind
SMPPClientFactory(self.config, self.handleMsg).connect().addErrback(self.connectFailed)
except Exception, e:
print "ERROR: %s" % str(e)
def connectFailed(self, reason):
print "Connection failed %s" % str(reason)
def handleMsg(self, smpp, pdu):
pass
if __name__ == '__main__':
config = SMPPClientConfig(host='127.0.0.1', port=2775, username='smppclient1', password='password',
log_level=logging.DEBUG)
logging.basicConfig(level=config.log_level, filename=config.log_file, format=config.log_format,datefmt=config.log_dateformat)
SMPP(config).run()
reactor.run()
当连接失败(远程服务器宕机)时,我会得到工厂的 clientConnectionFailed 被调用,但奇怪的是,它出现了一个“exceptions.AttributeError: SMPPClientFactory 实例没有属性 'connectDeferred'”的错误。
我需要在连接失败时调用 errback,似乎在处理 deferreds 时缺少了一些东西……
1 个回答
2
在你的启动代码中,你创建了一个SMPPClientFactory的实例,并在它上面调用了connect()方法。这个特定的实例会有一个叫做connectDeferred的属性。不过,connect方法还创建了另一个SMPPClientFactory的实例:factory = SMPPClientFactory(self.config, self.msgHandler)
,而这个实例是用来建立实际连接的。这个实例没有connectDeferred属性,因为在这个实例上从来没有调用过connect方法。