如何通过redis-cli显示所有密钥?

Ste*_*ano 51 django redis

我使用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',
        },
    },
}
Run Code Online (Sandbox Code Playgroud)

我的django缓存似乎工作正常.

奇怪的是我无法使用redis-cli命令行看到django缓存键.

[编辑] 请注意以下我试过两个

$ redis-cli
Run Code Online (Sandbox Code Playgroud)

$ redis-cli -s /tmp/redis_6379.sock
Run Code Online (Sandbox Code Playgroud)

[EndEdit中]

没有区别.

特别是,使用KEYS *命令:

$ redis-cli
redis 127.0.0.1:6379> keys *
(empty list or set)
Run Code Online (Sandbox Code Playgroud)

redis 127.0.0.1:6379> set stefano test
OK
redis 127.0.0.1:6379> keys *
1) "stefano"
Run Code Online (Sandbox Code Playgroud)

而来自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']
Run Code Online (Sandbox Code Playgroud)

如果我MONITOR在cli上使用:

redis 127.0.0.1:6379> monitor
OK
1373372711.017761 [1 unix:/tmp/redis_6379.sock] "KEYS" "project_prefix:1:*"
Run Code Online (Sandbox Code Playgroud)

我可以使用django缓存前缀查看请求; 这应该证明redis-cli连接到同一个服务.但即使在redis-cli返回中搜索该前缀也是如此(empty list or set)

这是为什么?

在同一个redis实例上划分不同缓存的机制是什么?

Did*_*zia 70

我想说有两种可能性:

1/django应用程序可能无法连接到您认为已连接的Redis实例,或者您启动的redis-cli客户端未连接到同一Redis实例.

请注意,在这两种情况下,您都不使用相同的连接机制.Django使用Unix域套接字,而redis-cli使用TCP环回(默认情况下).您可能希望使用相同的套接字路径启动redis-cli,以确保:

$ redis-cli -s /tmp/redis_6379.sock
Run Code Online (Sandbox Code Playgroud)

现在,由于您已经使用MONITOR命令验证了Django发送的命令,我们可以假设您已连接到正确的实例.

2/Redis中有一个数据库概念.默认情况下,您有16个不同的数据库,当前的默认数据库为0. SELECT命令可用于将会话切换到另一个数据库.每个数据库有一个键空间.

INFO KEYSPACE命令可用于检查是否在多个数据库中定义了某些键.

redis 127.0.0.1:6379[1]> info keyspace
# Keyspace
db0:keys=1,expires=0
db1:keys=1,expires=0
Run Code Online (Sandbox Code Playgroud)

这里我有两个数据库,让我们检查db0数据库中定义的键:

redis 127.0.0.1:6379> keys *
1) "foo"
Run Code Online (Sandbox Code Playgroud)

现在在db1数据库中:

redis 127.0.0.1:6379> select 1
OK
redis 127.0.0.1:6379[1]> keys *
1) "bar"
Run Code Online (Sandbox Code Playgroud)

我的建议还是检查Django应用程序是否在连接时将任何SELECT命令发送到Redis实例(使用MONITOR).

我不熟悉Django,但是你定义LOCATION参数的方式让我觉得你的数据可能在数据库1中(由于后缀).

  • 谢谢Didier.我已经排除了1)因为我也试过直接连接到套接字,我看到没有区别.但我不知道"SELECT"命令!这完全是它!现在正在工作......我必须说Redis关于这一点的文档不是很清楚.即使查看[Redis SELECT](http://redis.io/commands/select)命令文档也会显示一堆混淆的评论! (2认同)