首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何通过redis-cli显示所有密钥?

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

Stack Overflow用户
提问于 2013-07-09 20:29:11
回答 2查看 87.8K关注 0票数 60

我使用redis作为django缓存的内存数据库后端。

具体地说,我使用的django-redis配置如下:

代码语言:javascript
运行
复制
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缓存键。

编辑请注意,在下面的代码中,我尝试了使用

代码语言:javascript
运行
复制
$ redis-cli

代码语言:javascript
运行
复制
$ redis-cli -s /tmp/redis_6379.sock

endedit

没有区别。

特别是,使用KEYS *命令:

代码语言:javascript
运行
复制
$ redis-cli
redis 127.0.0.1:6379> keys *
(empty list or set)

代码语言:javascript
运行
复制
redis 127.0.0.1:6379> set stefano test
OK
redis 127.0.0.1:6379> keys *
1) "stefano"

而在django shell中:

代码语言:javascript
运行
复制
In [1]: from django.core.cache import cache

In [2]: cache.keys('*')
Out[2]:
[u'django.contrib.sessions.cachebblhwb3chd6ev2bd85bawuz7g6pgaij8',
 u'django.contrib.sessions.cachewpxiheosc8qv5w4v6k3ml8cslcahiwna']

如果我在cli上使用MONITOR

代码语言:javascript
运行
复制
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实例上划分不同缓存的机制是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-07-10 01:22:49

我想说有两种可能性:

1/ django应用可能没有连接到您认为它连接的Redis实例,或者您启动的redis-cli客户端没有连接到同一个Redis实例。

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

代码语言:javascript
运行
复制
$ redis-cli -s /tmp/redis_6379.sock

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

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

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

代码语言:javascript
运行
复制
redis 127.0.0.1:6379[1]> info keyspace
# Keyspace
db0:keys=1,expires=0
db1:keys=1,expires=0

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

代码语言:javascript
运行
复制
redis 127.0.0.1:6379> keys *
1) "foo"

现在在db1数据库中:

代码语言:javascript
运行
复制
redis 127.0.0.1:6379> select 1
OK
redis 127.0.0.1:6379[1]> keys *
1) "bar"

我的建议也是检查Django应用程序是否在连接时向Redis实例(使用监视器)发送任何SELECT命令。

我不熟悉Django,但是您定义LOCATION参数的方式让我认为您的数据可能在数据库1中(由于后缀)。

票数 79
EN

Stack Overflow用户

发布于 2016-08-01 14:19:42

执行以下操作:

代码语言:javascript
运行
复制
redis-cli -h <host> KEYS "trendingKey*"

输出

  1. "trendingKey:2:1"
  2. "trendingKey:trending102:1"
  3. "trendingKey:trending101:1"
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17548188

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档