changes
This commit is contained in:
@ -1,24 +1,30 @@
|
||||
import threading
|
||||
import time
|
||||
from logger import Logger
|
||||
|
||||
class Expirer(threading.Thread):
|
||||
def __init__(self, entries, eventLifeTime, nullAddress):
|
||||
def __init__(self, entries, eventLifeTime, nullAddress, dnsq):
|
||||
threading.Thread.__init__(self)
|
||||
self.entries = entries
|
||||
self.eventLifeTime = eventLifeTime
|
||||
self.nullAddress = nullAddress
|
||||
self.dnsq = dnsq
|
||||
self.setDaemon(True)
|
||||
|
||||
def run(self):
|
||||
while True:
|
||||
print "Expiring ..."
|
||||
Logger.log("Expiring ...")
|
||||
currentTime = int(time.time())
|
||||
for entry in self.entries.values():
|
||||
print "Checking ", str(entry)
|
||||
Logger.log("Checking %s" % str(entry))
|
||||
if entry.lastEventTime != 0 and entry.lastEventTime + self.eventLifeTime < currentTime:
|
||||
print "Entry %s expired" % entry.dynid
|
||||
Logger.log("Entry %s expired" % entry.dynid)
|
||||
entry.lastEventTime = 0
|
||||
entry.address = self.nullAddress
|
||||
print "Set in DNS: %s -> %s" % (entry.name, entry.address)
|
||||
Logger.log("Set in DNS: %s -> %s" % (entry.name, entry.address))
|
||||
try:
|
||||
self.dnsq.put_nowait(entry)
|
||||
except Queue.Full, e:
|
||||
Logger.log("Dns Queue overrun, drop expiry of %s" % str(entry))
|
||||
time.sleep(10)
|
||||
|
||||
|
Reference in New Issue
Block a user