在Redis中有办法打印键的数量吗?
我知道
keys *
但这似乎有点沉重。考虑到Redis是一个键值存储,也许这是唯一的方法。但我还是希望看到一些类似于
count keys *
在Redis中有办法打印键的数量吗?
我知道
keys *
但这似乎有点沉重。考虑到Redis是一个键值存储,也许这是唯一的方法。但我还是希望看到一些类似于
count keys *
当前回答
警告:不要在生产机器上运行此程序。
Linux系统:
redis-cli KEYS "*" | wc -l
注意:正如下面的评论中提到的,这是一个O(N)操作,所以在一个有很多键的大数据库上,你不应该使用它。对于较小的部署,应该没问题。
其他回答
警告:不要在生产机器上运行此程序。
Linux系统:
redis-cli KEYS "*" | wc -l
注意:正如下面的评论中提到的,这是一个O(N)操作,所以在一个有很多键的大数据库上,你不应该使用它。对于较小的部署,应该没问题。
eval "local count = redis.call('scan', 0, 'match', 'key:*:key', 'count', 10000) if count ~= 0 then return #count[2] end " 0
eval "local count = redis.call('sscan', 'key.key:all', 0, 'match', '*', 'count', 1000000) if count ~= 0 then return #count[2] end " 0
进入redis-cli,使用以下命令
info keyspace
它可能会帮助到某人
显示DB的名称和键数:
redis-cli info keyspace
# Keyspace
db0:keys=12995,expires=0,avg_ttl=0
db12:keys=5524396,expires=5,avg_ttl=45201
显示编号。所选数据库中的键:
redis-cli dbsize
(integer) 12995
显示整个Redis的统计数据:
redis-cli info
Dbsize()返回键的总数。
您可以通过随机抽样键来快速估计与给定模式匹配的键的数量,然后检查它们中有多少与模式匹配。
python中的示例;计数所有前缀_开头的键:
import redis
r = redis.StrictRedis(host = 'localhost', port=6379)
iter=1000
print 'Approximately', r.dbsize() * float(sum([r.randomkey().startswith('prefix_') for i in xrange(iter)])) / iter
在我的情况下,即使iter=100给出了一个不错的估计,但与keys prefix_相比,它非常快。
一种改进方法是对每个请求采样1000个键,但保持总计数,这样在两个请求后将除以2000,在三个请求后将除以3000。因此,如果应用程序经常对匹配键的总数感兴趣,那么每次它都会越来越接近真实值。