python - Django Memcache操作

 派沃控制阀_689 发布于 2022-10-31 15:02

请问,不同的django服务,能共享同一个memcache当中的内容吗?为什么我在一个django服务中进行缓存的保存,在别的django服务中获取不到对应key的值呢

在django1.7的一个服务中如下:

from django.core.cache import cache
cache.set('mine', mine)

m = cache.get('mine')
print m

当中的mine是一个obj,在自己服务中获取是没有问题的

在另一个django1.5的服务中如下:

from django.core.cache import cache
m = cache.get('mine')
print m

在这里m就是None了

ps:两个django服务的链接的memcache都是一样的

3 个回答
  • 我用 django 的 cache 遇到过类似的问题.
    但我使用的 backend 是 LocMemCache.
    就是把 key 存到内存中。
    但这里面的坑是,多个 django 进程并不共享一块内存。
    可能第一次访问的时候是被进程1 处理的,第二次访问却被进程2处理,导致缓存未命中。

    2022-11-12 01:49 回答
  • 前缀不一样的可能性极大

    2022-11-12 01:49 回答
  • 我推测有两种可能性:

    1、set时候的key并不是真正存放在cache中的key,也许增加了前缀,不同的版本可能前缀也不一样

    2、memcached 中存放的应该是一个序列号后的对象,不同版本的django可能序列号算法不一样,你可以set一个简单的值验证一下。

    2022-11-12 01:49 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有