首页 > 解决方案 > 共享memcache节点的django问题

问题描述

我有两个 django 实例在两台服务器上运行,我正在使用 memcached 在我的应用程序中缓存一些数据。每台服务器都安装了自己的 memcached,我希望我的两个应用程序都可以访问两个缓存,但我不能。当我从缓存中的一个应用程序设置值时,其他应用程序无法访问它

我的 memcached 实例以 root 身份运行,我也尝试过 memcache 和其他用户,但它没有解决问题。为了测试我使用了 django shell,导入缓存类:

from django.core.cache import cache

在缓存中设置一个值:

cache.set('foo', 'bar', 3000)

并试图从我的其他 Django 实例中获取价值:

cache.get('foo')

但它什么也没返回!

这是我的 settings.py 文件:

CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
        'LOCATION': [
                     'first app server ip:port',
                     'second app server ip:port']

    }
}

和我的 memcached.conf(评论已删除):

-d

logfile /var/log/memcache/memcached.log

# -v

-vv

-m 512

-p 11211

-u root

-l 192.168.174.160

# -c 1024

# -k

# -M

# -r

-P /var/run/memcached/memcached.pid

标签: djangomemcached

解决方案


设置中的位置顺序在所有服务器中必须相同。你能检查一下它们是否相同吗?


推荐阅读