如何重复使用twisted来调用函数而不会遇到无限递归问题?

时间:2016-05-03 07:29:42

标签: python twisted dht kademlia

我正在使用twisted来处理P2P应用程序。我试图在我的DHT中重复搜索特定的密钥,并在值发生变化时将其添加到字典中。代码或多或少地做了我想要完成的事情,除了我得到一个新值后仍然有多个请求正在运行。这有时会给我一个运行时错误,说我已超过最大递归深度。如何更改此设置,以便一次只运行一个get请求,但它仍然不断搜索?我以前从来没有使用扭曲,所以我仍然试图抓住它。

#want this to loop repeatedly looking for new ids
def addid(val,server,key):
    print "Val: ",val
    if val:
        if not val in ids:
            print "new id found"
            valhash = hashlib.sha1()
            valhash.update(str(val))
            newval = valhash.hexdigest()
            ids[val]=newval
            server.set(ids[val], str(val))

    server.get(key).addCallback(addid,server,key)

def bootstrapDone(found, server):
    if len(found) == 0:
        print "Could not connect to the bootstrap server."
        reactor.stop()
    key = hashlib.sha1()
    key.update('specialstring')
    keyhash = key.hexdigest()
    server.get(keyhash).addCallback(addid,server,keyhash)

0 个答案:

没有答案