django上的memcache无效

时间:2017-05-09 22:43:49

标签: django memcached celery django-cache python-memcached

我在Celery中遇到了竞争条件。受此启发 - http://ask.github.io/celery/cookbook/tasks.html#ensuring-a-task-is-only-executed-one-at-a-time我决定使用memcache为我的任务添加锁。

以下是我所做的更改:

python-memcached

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

在此之后我登录我的shell并执行以下操作

>>> import os
>>> import django
>>> from django.core.cache import cache
>>> os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'proj.settings.base')
>>> cache
<django.core.cache.DefaultCacheProxy object at 0x101e4c860>
>>> cache.set('my_key', 'hello, world!', 30) #display nothing. No T/F
>>> cache.get('my_key') #Display nothing.
>>> from django.core.cache import caches
>>> caches['default']
<django.core.cache.backends.memcached.MemcachedCache object at 0x1048a5208>
>>> caches['default'].set('my_key', 'hello, world!', 30) #display nothing. No T/F
>>> caches['default'].get('my_key') #Display nothing.

也做了pip install python-memcached

使用Python 3.6Django==1.10.5

我做错了什么?任何帮助将不胜感激。

2 个答案:

答案 0 :(得分:4)

问题是 - 因为某种原因,memcached被杀了,我以为它还在运行。我的错。 现在它完美无缺。

对于遇到类似问题的人,您要确保运行memcached。 - memcached -vv

保留此处以供参考。

答案 1 :(得分:0)

如果您的安装看起来像是我的安装(在这种情况下,您表示同情;因为RHEL是一个平台,其中django似乎比本周的python更薄):

# yum upgrade -y
  yum-config-manager --add-repo=https://dl.fedoraproject.org/pub/epel/7/x86_64/

#  yum install -y emacs-nox
  yum install -y python{-sqlparse,36{,-{devel,pip,pytz,bcrypt}}} memcached

  service memcached start
  chkconfig memcached on

  python36 \
    -m pip install \
      django \
      pymemcache \
    --no-deps --upgrade 

然后使用我们20年来一直使用的相同命令轻松检查内存缓存的状态:

  service memcached status

在RHEL / EL7(#fridgeArt)上还可以使用其他命令,但是尽管有恢复驱动的差异,但我更喜欢兼容的工作流程。 >:-(

以下是在EL和debuntus下也使用-vv启动它的方法:https://stackoverflow.com/a/22239764/2066657