Source code for TileCache.Caches.Memcached

# BSD Licensed, Copyright (c) 2006-2010 TileCache Contributors

from TileCache.Cache import Cache
import time

[docs]class Memcached(Cache): def __init__ (self, servers = ['127.0.0.1:11211'], **kwargs): Cache.__init__(self, **kwargs) import memcache if type(servers) is str: servers = map(str.strip, servers.split(",")) self.cache = memcache.Client(servers, debug=0)
[docs] def getKey(self, tile): return "/".join(map(str, [tile.layer.name, tile.x, tile.y, tile.z]))
[docs] def get(self, tile): key = self.getKey(tile) tile.data = self.cache.get(key) return tile.data
[docs] def set(self, tile, data): if self.readonly: return data key = self.getKey(tile) self.cache.set(key, data) return data
[docs] def delete(self, tile): key = self.getKey(tile) self.cache.delete(key)
[docs] def attemptLock (self, tile): return self.cache.add( self.getLockName(tile), "0", time.time() + self.timeout)
[docs] def unlock (self, tile): self.cache.delete( self.getLockName(tile) )