yadyn/server/Expirer.py

34 lines
1.2 KiB
Python
Raw Normal View History

2007-11-12 11:17:25 +01:00
import threading
import time
2007-11-13 11:44:47 +01:00
from logger import Logger
2007-11-12 11:17:25 +01:00
class Expirer(threading.Thread):
2007-11-13 12:00:44 +01:00
def __init__(self, entries, eventLifeTime, nullAddress, expiryPeriod, dnsq):
2007-11-12 11:17:25 +01:00
threading.Thread.__init__(self)
self.entries = entries
self.eventLifeTime = eventLifeTime
self.nullAddress = nullAddress
2007-11-13 12:00:44 +01:00
self.expiryPeriod = expiryPeriod
2007-11-13 11:44:47 +01:00
self.dnsq = dnsq
2007-11-12 11:17:25 +01:00
self.setDaemon(True)
def run(self):
while True:
2007-11-16 09:19:26 +01:00
Logger.debug("Expiring ...")
2007-11-12 11:17:25 +01:00
currentTime = int(time.time())
for entry in self.entries.values():
2007-11-16 09:19:26 +01:00
Logger.debug("Checking %s" % str(entry))
2007-11-12 11:17:25 +01:00
if entry.lastEventTime != 0 and entry.lastEventTime + self.eventLifeTime < currentTime:
2007-11-16 09:19:26 +01:00
Logger.debug("Entry %s expired" % entry.dynid)
2007-11-12 11:17:25 +01:00
entry.lastEventTime = 0
entry.address = self.nullAddress
2007-11-16 09:19:26 +01:00
Logger.debug("Set in DNS: %s -> %s" % (entry.name, entry.address))
2007-11-13 11:44:47 +01:00
try:
self.dnsq.put_nowait(entry)
except Queue.Full, e:
Logger.log("Dns Queue overrun, drop expiry of %s" % str(entry))
2007-11-13 12:00:44 +01:00
time.sleep(self.expiryPeriod)
2007-11-12 11:17:25 +01:00
2007-11-23 13:56:33 +01:00