为了账号安全,请及时绑定邮箱和手机立即绑定

Django Memcache操作

Django Memcache操作

慕村9548890 2018-07-15 22:17:39
请问,不同的django服务,能共享同一个memcache当中的内容吗?为什么我在一个django服务中进行缓存的保存,在别的django服务中获取不到对应key的值呢在django1.7的一个服务中如下:from django.core.cache import cachecache.set('mine', mine) m = cache.get('mine') print m当中的mine是一个obj,在自己服务中获取是没有问题的在另一个django1.5的服务中如下:from django.core.cache import cachem = cache.get('mine') print m在这里m就是None了ps:两个django服务的链接的memcache都是一样的

3 回答

?
慕少森

TA贡献2019条经验 获得超9个赞

前缀不一样的可能性极大

查看完整回答
反对 回复 2018-07-20
?
达令说

TA贡献1821条经验 获得超6个赞

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

查看完整回答
反对 回复 2018-07-20
?
白板的微信

TA贡献1883条经验 获得超3个赞

我推测有两种可能性:

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

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


查看完整回答
反对 回复 2018-07-20

添加回答

代码语言

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号