This project is specifically designed for asynchronous Python Twisted code to interact with multiple memcached servers. A number of other libraries exist, but none of them supported all of the following:
- A reconnecting client: if a connection is closed the client should keep trying to reconnect
- (Consistent) Partitioning: You should be able to use as many memached servers as you'd like and partition the keys between them, and this should use consistent hashing
- Pickling/Compression: You should be able to effortlessly store objects (and have them compressed if you'd like)
pip install txyam
Usage is pretty straightforward:
# import the client
from txyam.client import YamClient
# create a new client - hosts are either hostnames
# (default port of 11211 will be used) or host/port tuples
hosts = [ 'localhost', 'otherhost', ('someotherhost', 123) ]
client = YamClient(hosts)
# Run some commands. You can use all of the typical get/add/replace/etc listed at:
# http://twistedmatrix.com/documents/current/api/twisted.protocols.memcache.MemCacheProtocol.html
client.set('akey', 'avalue').addCallback(someHandler)
# Additionally, you can set / add / get picked objects
client.addPickled('anotherkey', { 'dkey': [1, 2, 3] }, compress=True)
client.getPickled('anotherkey', uncompress=True)
# get stats for all servers
def printStats(stats):
for host, statlist in stats.items():
print host, statlist['bytes']
client.stats().addCallback(printStats)
You can use txyam to memoize functions/methods.
# assuming "client" is already defined and is a YamClient
@memoize(client)
def mayTakeAWhile(arg, argtwo):
return takesForever(arg, argtwo)
mayTakeAWhile('blah', 'blah two')
After the first time mayTakeAWhile
is called, the results are stored in memcache. All future
calls just pull the results from memcache. The function will be memoized based on the function
name and arguments. The function being memoized can return an object, which will be picked before saving.
See github.