/
rcdata.py
85 lines (73 loc) · 1.88 KB
/
rcdata.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
from mpycache import LRUCache
import socket
import signal
import voldemort
class RCLHT:
def __init__(self):
self.hashtable = {}
def get(self, key):
try:
return self.hashtable[key]
except:
return None
def put(self, key, value):
self.hashtable[key] = value
class TimeoutException(Exception):
pass
class RCDHT:
def __init__(self):
self.HOST = "localhost"
self.PORT = 9999
self.dht = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
self.cache = LRUCache(10000,0,0)
def get(self, key):
def timeout_handler(signum, frame):
raise TimeoutException()
value = self.cache.get(key)
if value == None:
self.dht.sendto("get "+key+"\n", (self.HOST, self.PORT))
signal.signal(signal.SIGALRM, timeout_handler)
signal.alarm(1)
try:
received = self.dht.recv(1024)
return received.strip()
except TimeoutException:
return ""
else:
return value
def put(self, key, value):
self.cache.put(key, value)
self.dht.sendto("put "+key+" "+value+"\n", (self.HOST, self.PORT))
class RCVoldemort:
def __init__(self,host):
self.dht = voldemort.StoreClient('force', [(host,6666)])
self.cache = LRUCache(100000,0,0)
def get(self, key):
value = self.cache.get(key)
if value == None:
resp = self.dht.get(key)
try:
return resp[0][0]
except:
return ""
else:
return value
def getall(self, keys):
missing = []
local = {}
for key in keys:
val = self.cache.get(key)
if val == None:
missing.append(key)
else:
local[key] = val
remote = self.dht.get_all(missing)
for key in remote:
local[key] = remote[key][0][0]
return local
def put(self, key, value):
self.cache.put(key, value)
try:
self.dht.put(key, value)
except (voldemort.client.VoldemortException):
pass