import memcache
from osrf.json import osrfObjectToJSON, osrfJSONToObject
+from osrf.log import *
'''
Abstracted OpenSRF caching interface.
'''
global _client
if servers:
- self.client = memcache.Client(server, debug=0)
+ self.client = memcache.Client(server, debug=1)
else:
if not _client:
raise CacheException("not connected to any memcache servers. try CacheClient.connect(servers)")
global defaultTimeout
if timeout is None:
timeout = defaultTimeout
- self.client.set(key, osrfObjectToJSON(val), timeout)
+ s = osrfObjectToJSON(val)
+ osrfLogInternal("cache: %s => %s" % (str(key), s))
+ return self.client.set(str(key), s, timeout)
def get(self, key):
- return osrfJSONToObject(self.client.get(key) or "null")
+ o = self.client.get(str(key))
+ osrfLogInternal("cache: fetching %s => %s" % (str(key), o))
+ return osrfJSONToObject(o or "null")
+
+ def delete(self, key):
+ osrfLogInternal("cache: deleting %s" % str(key))
+ self.client.delete(str(key))
@staticmethod
def connect(svrs):
global _client
- _client = memcache.Client(svrs, debug=0)
+ osrfLogDebug("cache: connecting to servers %s" % str(svrs))
+ _client = memcache.Client(svrs, debug=1)
if len(self.queue) == 0:
while timeout >= 0 and len(self.queue) == 0:
starttime = time.time()
- osrfLogInternal("going into stream loop at " + str(starttime))
act = self.get_stream().loop_iter(timeout)
endtime = time.time() - starttime
timeout -= endtime
- osrfLogInternal("exiting stream loop after %s seconds" % str(endtime))
- osrfLogInternal("act = %s : queue length = %d" % (act, len(self.queue)) )
+ osrfLogInternal("exiting stream loop after %s seconds. act=%s, queue size=%d" % (str(endtime),act, len(self.queue)))
if not act: self.idle()
# if we've acquired a message, handle it