搜尋

首頁  >  問答  >  主體

redis分好庫之後怎麼才能看每個庫的大小呢?

我redis裏配置了db0、db1、db2、db3四個庫,我想看每個庫分別占用的大小應該怎麼辦?
另外jedis裏有什麼方法可以用嗎?

怪我咯怪我咯2798 天前713

全部回覆(1)我來回復

  • PHPz

    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 資訊。

    回覆
    0
  • 取消回覆