我使用 redis 作为 django 缓存的内存数据库后端。
特别是,我使用django-redis配置如下:
CACHES = {
'default': {
'BACKEND': 'redis_cache.cache.RedisCache',
'KEY_PREFIX': DOMAIN_NAME,
'LOCATION': 'unix:/tmp/redis_6379.sock:1',
'OPTIONS': {
'PICKLE_VERSION': -1, # default
'PARSER_CLASS': 'redis.connection.HiredisParser',
'CLIENT_CLASS': 'redis_cache.client.DefaultClient',
},
},
}
我的 django 缓存似乎工作正常。
奇怪的是,我无法使用redis-cli
命令行查看 django 缓存键。
[编辑] 请注意以下我都尝试过
$ redis-cli
和
$ redis-cli -s /tmp/redis_6379.sock
[已完结]
没有区别。
特别是,使用以下KEYS *
命令:
$ redis-cli
redis 127.0.0.1:6379> keys *
(empty list or set)
但
redis 127.0.0.1:6379> set stefano test
OK
redis 127.0.0.1:6379> keys *
1) "stefano"
而来自 django shell:
In [1]: from django.core.cache import cache
In [2]: cache.keys('*')
Out[2]:
[u'django.contrib.sessions.cachebblhwb3chd6ev2bd85bawuz7g6pgaij8',
u'django.contrib.sessions.cachewpxiheosc8qv5w4v6k3ml8cslcahiwna']
如果我MONITOR
在 cli 上使用:
redis 127.0.0.1:6379> monitor
OK
1373372711.017761 [1 unix:/tmp/redis_6379.sock] "KEYS" "project_prefix:1:*"
我可以看到一个请求,使用 django 缓存前缀;这应该证明 redis-cli 连接到相同的服务。redis-cli
但即使在返回中搜索该前缀(empty list or set)
这是为什么?
在同一个 redis 实例上划分不同缓存的机制是什么?