我将 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
:
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
中搜索该前缀甚至返回了一个(空列表或集合)
为什么会这样呢?
有什么机制可以将同一个redis实例上的不同缓存隔离开来吗?