andy boot
andy boot

Reputation: 11757

Print number of keys in Redis

Is there a way to print the number of keys in Redis?

I am aware of

keys *

But that seems slightly heavy weight. - Given that Redis is a key value store maybe this is the only way to do it. But I would still like to see something along the lines of

count keys *

Upvotes: 251

Views: 311849

Answers (10)

AATHITH RAJENDRAN
AATHITH RAJENDRAN

Reputation: 5386

  1. Displays the DB's name along with keys count:
redis-cli info keyspace
# Keyspace
db0:keys=12995,expires=0,avg_ttl=0
db12:keys=5524396,expires=5,avg_ttl=45201
  1. Display the no. of keys in the selected database:
redis-cli dbsize
(integer) 12995
  1. Displays whole Redis's stats:
redis-cli info

Upvotes: 13

Pankaj Chauhan
Pankaj Chauhan

Reputation: 1715

The DBSIZE command returns the number of keys

> DBSIZE

Upvotes: 83

Nouman Mukhtar
Nouman Mukhtar

Reputation: 389

Go to redis-cli and use below command

info keyspace

It may help someone

Upvotes: 15

hymloth
hymloth

Reputation: 7045

You can issue the INFO command, which returns information and statistics about the server. See here for an example output.

As mentioned in the comments by mVChr, you can use info keyspace directly on the redis-cli.

redis> INFO
# Server
redis_version:6.0.6
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:b63575307aaffe0a
redis_mode:standalone
os:Linux 5.4.0-1017-aws x86_64
arch_bits:64
multiplexing_api:epoll
atomicvar_api:atomic-builtin
gcc_version:9.3.0
process_id:2854672
run_id:90a5246f10e0aeb6b02cc2765b485d841ffc924e
tcp_port:6379
uptime_in_seconds:2593097
uptime_in_days:30
hz:10
configured_hz:10
lru_clock:4030200
executable:/usr/local/bin/redis-server

Upvotes: 271

reptilicus
reptilicus

Reputation: 10407

WARNING: Do not run this on a production machine.

On a Linux box:

redis-cli KEYS "*" | wc -l

Note: As mentioned in comments below, this is an O(N) operation, so on a large DB with many keys you should not use this. For smaller deployments, it should be fine.

Upvotes: 50

Laoch Tan
Laoch Tan

Reputation: 1

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

Upvotes: -1

seppo0010
seppo0010

Reputation: 15879

DBSIZE returns the number of keys and it's easier to parse.

Downside: if a key has expired it may still count.

http://redis.io/commands/dbsize

Upvotes: 248

Sergey Orshanskiy
Sergey Orshanskiy

Reputation: 7054

dbsize() returns the total number of keys.

You can quickly estimate the number of keys matching a given pattern by sampling keys at random, then checking what fraction of them matches the pattern.

Example in python; counting all keys starting with prefix_:

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

Even iter=100 gives a decent estimate in my case, yet is very fast, compared to keys prefix_.

An improvement is to sample 1000 keys on every request, but keep the total count, so that after two requests you'll divide by 2000, after three requests you'll divide by 3000. Thus, if your application is interested in the total number of matching keys fairly often, then every time it will get closer and closer to the true value.

Upvotes: 5

jingchao
jingchao

Reputation: 672

Since Redis 2.6, lua is supported, you can get number of wildcard keys like this

eval "return #redis.call('keys', 'prefix-*')" 0

see eval command

Upvotes: 30

Jiankuan Xing
Jiankuan Xing

Reputation: 387

After Redis 2.6, the result of INFO command are splitted by sections. In the "keyspace" section, there are "keys" and "expired keys" fields to tell how many keys are there.

Upvotes: 0

Related Questions