主頁 > 知識(shí)庫 > Redis中統(tǒng)計(jì)各種數(shù)據(jù)大小的方法

Redis中統(tǒng)計(jì)各種數(shù)據(jù)大小的方法

熱門標(biāo)簽:hbuilder地圖標(biāo)注 高德地圖標(biāo)注商家在哪 隨州營銷電話機(jī)器人怎么樣 400電話申請?jiān)趺纯?/a> 400電話從哪里申請濱州 江西南昌百應(yīng)電話機(jī)器人 機(jī)器人電話機(jī)創(chuàng)意繪畫 天音通信電話機(jī)器人 杭州400電話如何申請的

如果 MySQL 數(shù)據(jù)庫比較大的話,我們很容易就能查出是哪些表占用的空間;不過如果 Redis 內(nèi)存比較大的話,我們就不太容易查出是哪些(種)鍵占用的空間了。

有一些工具能夠提供必要的幫助,比如 redis-rdb-tools 可以直接分析 RDB 文件來生成報(bào)告,可惜它不能百分百實(shí)現(xiàn)我的需求,而我也不想在它的基礎(chǔ)上二次開發(fā)。實(shí)際上開發(fā)一個(gè)專用工具非常簡單,利用 SCAN 和 DEBUG 等命令,沒多少行代碼就能實(shí)現(xiàn):

復(fù)制代碼 代碼如下:

?php

$patterns = array(
    'foo:.+',
    'bar:.+',
    '.+',
);

$redis = new Redis();
$redis->setOption(Redis::OPT_SCAN, Redis::SCAN_RETRY);

$result = array_fill_keys($patterns, 0);

while ($keys = $redis->scan($it, $match = '*', $count = 1000)) {
    foreach ($keys as $key) {
        foreach ($patterns as $pattern) {
            if (preg_match("/^{$pattern}$/", $key)) {
                if ($v = $redis->debug($key)) {
                    $result[$pattern] += $v['serializedlength'];
                }

                break;
            }
        }
    }
}

var_dump($result);

?>

當(dāng)然,前提是你需要提前總結(jié)出可能的鍵模式,簡單但不嚴(yán)謹(jǐn)?shù)姆椒ㄊ?MONITOR:

復(fù)制代碼 代碼如下:

shell> /path/to/redis-cli monitor |
       awk -F '"' '$2 ~ "ADD|SET|STORE|PUSH" {print $4}'

此外,需要注意的是:因?yàn)?DEBUG 返回的 serializedlength 是序列化后的長度,所以最終計(jì)算的值小于實(shí)際內(nèi)存占用,但考慮到相對大小依然是有參考意義的。

您可能感興趣的文章:
  • PHP+Redis 消息隊(duì)列 實(shí)現(xiàn)高并發(fā)下注冊人數(shù)統(tǒng)計(jì)的實(shí)例
  • 利用Redis統(tǒng)計(jì)網(wǎng)站在線活躍用戶的方法
  • PHP使用redis實(shí)現(xiàn)統(tǒng)計(jì)緩存mysql壓力的方法
  • 基于redis實(shí)現(xiàn)token驗(yàn)證用戶是否登陸
  • redis 實(shí)現(xiàn)登陸次數(shù)限制的思路詳解
  • redis開啟和禁用登陸密碼校驗(yàn)的方法
  • 基于Redis位圖實(shí)現(xiàn)系統(tǒng)用戶登錄統(tǒng)計(jì)

標(biāo)簽:昆明 常德 沈陽 鶴崗 保定 葫蘆島 石嘴山 招商

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis中統(tǒng)計(jì)各種數(shù)據(jù)大小的方法》,本文關(guān)鍵詞  Redis,中,統(tǒng)計(jì),各種,數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis中統(tǒng)計(jì)各種數(shù)據(jù)大小的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Redis中統(tǒng)計(jì)各種數(shù)據(jù)大小的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章