Memcached Compare-And-Set模式产生错误的结果

时间:2013-09-27 12:55:25

标签: django memcached python-memcached

我正在尝试按照Guido的说明实现memcached比较和设置模式:

http://neopythonic.blogspot.nl/2011/08/compare-and-set-in-memcache.html

然而,我似乎没有把它弄好,我不知道出了什么问题。下面的文件使用Django(1.4.5 Final)和python-memcache(1.48)。

settings.py

CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
        'LOCATION': '127.0.0.1:11211',
    }
}

djangocache.py

#!/usr/bin/env python
from django.core.cache import cache
import multiprocessing.dummy

django_key = "TEST"
cached_key = cache.make_key(django_key).encode("UTF-8")

def add_to_cache(item):
    client = cache._cache
    #client = cache._lib.Client(cache._servers)

    while True:
        items = client.gets(cached_key)
        if client.cas(cached_key, items+(item,)):
            break

if __name__ == "__main__":
    cache.set(django_key, ())

    p = multiprocessing.dummy.Pool(2)
    p.map(add_to_cache, range(10))
    print(len(cache.get(django_key)))

运行它:

mzialla@Q330 ~/test $ DJANGO_SETTINGS_MODULE=settings python djangocache.py
5

偶尔输出6,7等等,就像你在处理比赛条件时所期望的那样。我尝试了多个客户端实例化(请参阅注释)。

帮助?

1 个答案:

答案 0 :(得分:3)

python-memcached默认禁用cas。通过添加

启用它
 client.cache_cas = True

代码。

Nate Thelen的信用,我在问这个问题之后发现了他的评论。

相关问题