summaryrefslogtreecommitdiffstats
path: root/openstack/common
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2013-03-01 21:43:27 +0000
committerGerrit Code Review <review@openstack.org>2013-03-01 21:43:27 +0000
commit5dbece5ac9485c3d34c84e257cf90562532c920b (patch)
tree0b4a4ed50bff0508b7f54af24ad001495073830f /openstack/common
parent5c54569951a3ce70c8aef6af906722f6fbfce8d9 (diff)
parent844123e2197358a2aeb39feb7275305f55b03e38 (diff)
downloadoslo-5dbece5ac9485c3d34c84e257cf90562532c920b.tar.gz
oslo-5dbece5ac9485c3d34c84e257cf90562532c920b.tar.xz
oslo-5dbece5ac9485c3d34c84e257cf90562532c920b.zip
Merge "Add simple in-memory cache from nova."
Diffstat (limited to 'openstack/common')
-rw-r--r--openstack/common/memorycache.py96
1 files changed, 96 insertions, 0 deletions
diff --git a/openstack/common/memorycache.py b/openstack/common/memorycache.py
new file mode 100644
index 0000000..23847e6
--- /dev/null
+++ b/openstack/common/memorycache.py
@@ -0,0 +1,96 @@
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+# Copyright 2010 United States Government as represented by the
+# Administrator of the National Aeronautics and Space Administration.
+# All Rights Reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+
+"""Super simple fake memcache client."""
+
+from oslo.config import cfg
+
+from openstack.common import timeutils
+
+memcache_opts = [
+ cfg.ListOpt('memcached_servers',
+ default=None,
+ help='Memcached servers or None for in process cache.'),
+]
+
+CONF = cfg.CONF
+CONF.register_opts(memcache_opts)
+
+
+def get_client(memcached_servers=None):
+ client_cls = Client
+
+ if not memcached_servers:
+ memcached_servers = CONF.memcached_servers
+ if memcached_servers:
+ try:
+ import memcache
+ client_cls = memcache.Client
+ except ImportError:
+ pass
+
+ return client_cls(memcached_servers, debug=0)
+
+
+class Client(object):
+ """Replicates a tiny subset of memcached client interface."""
+
+ def __init__(self, *args, **kwargs):
+ """Ignores the passed in args."""
+ self.cache = {}
+
+ def get(self, key):
+ """Retrieves the value for a key or None.
+
+ this expunges expired keys during each get"""
+
+ now = timeutils.utcnow_ts()
+ for k in self.cache.keys():
+ (timeout, _value) = self.cache[k]
+ if timeout and now >= timeout:
+ del self.cache[k]
+
+ return self.cache.get(key, (0, None))[1]
+
+ def set(self, key, value, time=0, min_compress_len=0):
+ """Sets the value for a key."""
+ timeout = 0
+ if time != 0:
+ timeout = timeutils.utcnow_ts() + time
+ self.cache[key] = (timeout, value)
+ return True
+
+ def add(self, key, value, time=0, min_compress_len=0):
+ """Sets the value for a key if it doesn't exist."""
+ if self.get(key) is not None:
+ return False
+ return self.set(key, value, time, min_compress_len)
+
+ def incr(self, key, delta=1):
+ """Increments the value for a key."""
+ value = self.get(key)
+ if value is None:
+ return None
+ new_value = int(value) + delta
+ self.cache[key] = (self.cache[key][0], str(new_value))
+ return new_value
+
+ def delete(self, key, time=0):
+ """Deletes the value associated with a key."""
+ if key in self.cache:
+ del self.cache[key]