-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlocator.py
96 lines (76 loc) · 1.85 KB
/
locator.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import time
import netutil
import collections
BUFFER_SIZE = 5
LEASE = 60
gm = netutil.GrandMasterServer()
MAP = collections.defaultdict(lambda: None)
Qs = collections.defaultdict(lambda:
collections.defaultdict(lambda: []))
FAMILYQ = []
def suggest(trace):
part = str(trace)
parent = MAP[part]
if parent is None:
print 'SUGGEST: {0} => None'.format(part)
else:
parent = parent[0]
print 'SUGGEST: {0} => {1[0]}:{1[1]}'.format(part, parent)
return parent
def announce( (host, port), trace):
print 'ANNOUNCE: {0}:{1} for {2}'.format(host, port, trace)
MAP[str(trace)] = ((host, port), time.time() + LEASE)
def push(qname, net, value):
print Qs
net = str(net)
print 'push for: ', net
print Qs[qname][net]
l = Qs[qname][net]
print l, value
l.append(value)
if len(l) > BUFFER_SIZE:
for x in l:
FAMILYQ.append(x)
Qs[qname][net] = []
def pull(qname, net):
print Qs
net = str(net)
print 'Pull for: ', net
if len(Qs[qname][net]) > 0:
print 'Hit local!'
v = Qs[qname][net].pop(0)
print 'Got :', v
return v
else:
print 'Nothing in local queue'
if len(FAMILYQ) > 0:
return FAMILYQ.pop(0)
for k in Qs[qname].keys():
if len(Qs[qname][k]) > 0:
print 'Found something for: ', k
return Qs[k].pop(0)
print 'Found nothing for you.'
return None
gm.register(suggest)
gm.register(announce)
gm.register(push)
gm.register(pull)
gm.start()
try:
while True:
for i in xrange(4):
for ke in MAP.keys():
print ke, ':'.join(map[k][0])
time.sleep(20)
nao = time.time()
bad = filter(lambda k: MAP[k][1] < nao, MAP.keys())
for b in bad:
print 'Expire: ', b
del MAP[b]
except KeyboardInterrupt:
print '-- Exiting.'
gm._Thread__stop()
raise SystemExit
print '----------------- WHAT?'
gm._Thread__stop()
raise SystemExit