是否有一个Redis命令获取数据库中的所有键?我见过一些python-redis库获取它们。但我想知道从redis-client是否可以。


当前回答

我们应该在redis 2.8及以后的版本中使用——scan——pattern。

您可以尝试在redis-cli之上使用这个包装器。 https://github.com/VijayantSoni/redis-helper

其他回答

键模式

自1.0.0起可用。 时间复杂度:O(N), N为数字 数据库中的键,假设键名在 数据库和给定模式的长度是有限的。

返回所有匹配模式的键。

警告:不建议使用此命令,因为它可能会破坏性能,当它针对大型数据库执行时,可以使用SCAN或SETS代替KEYS。

KEYS命令使用示例:

redis> MSET firstname Jack lastname Stuntman age 35
"OK"
redis> KEYS *name*
1) "lastname"
2) "firstname"
redis> KEYS a??
1) "age"
redis> KEYS *
1) "lastname"
2) "age"
3) "firstname"

使用redis-cli,你可以连接到你的远程redis-server,然后命令:

KEYS *

没有显示任何东西,或者更好,它显示: (空列表或集合)

如果你绝对确定你使用的Redis服务器就是你拥有数据的服务器,那么可能你的Redis -cli没有连接到正确的Redis数据库实例。

正如Redis文档中提到的,新连接默认连接到db 0。

在我的情况下,KEYS命令没有检索结果,因为我的数据库是1。为了选择您想要的db,请使用select。 db用整数标识。

SELECT 1
KEYS *

我发布这个信息是因为之前的答案都没有解决我的问题。

在Redis中获得所有键

使用——scan选项获取所有键:

$ redis-cli --scan --pattern '*'

使用keys命令列出所有密钥:

$ redis-cli KEYS '*'

如果你正在使用Laravel框架,那么你可以简单地使用这个:

$allKeyList = Redis::KEYS("*");

print_r($allKeyList);

在核心PHP:

$redis = new Redis();

$redis->connect('hostname', 6379);

$allKeyList = $redis->keys('*');

print_r($allKeyList);
redis-cli -h <host> -p <port> keys * 

哪里*是列出所有键的模式