我redis裏配置了db0、db1、db2、db3四個庫,我想看每個庫分別占用的大小應該怎麼辦?
另外jedis裏有什麼方法可以用嗎?
PHPz2017-04-21 11:19:09
redis 看起來沒有提供一個可靠的方法來獲得每個 db 的實際佔用,這主要是因為 redis 本身就沒有 db 檔案概念,所有 db 都是混在一個 rdb 檔案裡面的。
要估算 db 的大小,需要透過 keys *
遍历 db 里所有的 key,然后用 debug object <key>
来获得 key 的内存占用,serializedlength
就是佔用記憶體的欄位長度。
根據 RDB 格式文檔,可以估算出每個 key 的實際佔用為:
key_size = strlen(key) + serializedlength + 7
不過這個估算極不靠譜,因為 redis 可能會將 key 做壓縮,此時估算出來的值可能偏大。
下面的指令可以查看 db0
的大小(key 個數),其他的以此類推。
select 0
dbsize
或使用 info keyspace
同時得到所有 db 資訊。