Redis中統(tǒng)計(jì)各種數(shù)據(jù)大小的方法
如果 MySQL 數(shù)據(jù)庫(kù)比較大的話,我們很容易就能查出是哪些表占用的空間;不過(guò)如果 Redis 內(nèi)存比較大的話,我們就不太容易查出是哪些(種)鍵占用的空間了。
有一些工具能夠提供必要的幫助,比如 redis-rdb-tools 可以直接分析 RDB 文件來(lái)生成報(bào)告,可惜它不能百分百實(shí)現(xiàn)我的需求,而我也不想在它的基礎(chǔ)上二次開發(fā)。實(shí)際上開發(fā)一個(gè)專用工具非常簡(jiǎn)單,利用 SCAN 和 DEBUG 等命令,沒(méi)多少行代碼就能實(shí)現(xiàn):
<?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é)出可能的鍵模式,簡(jiǎn)單但不嚴(yán)謹(jǐn)?shù)姆椒ㄊ?MONITOR:
shell> /path/to/redis-cli monitor |
awk -F '"' '$2 ~ "ADD|SET|STORE|PUSH" {print $4}'
此外,需要注意的是:因?yàn)?DEBUG 返回的 serializedlength 是序列化后的長(zhǎng)度,所以最終計(jì)算的值小于實(shí)際內(nèi)存占用,但考慮到相對(duì)大小依然是有參考意義的。
相關(guān)文章
Redis自動(dòng)化安裝及集群實(shí)現(xiàn)搭建過(guò)程
這篇文章主要介紹了Redis自動(dòng)化安裝以及集群實(shí)現(xiàn)搭建過(guò)程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09Redis實(shí)現(xiàn)延遲任務(wù)的三種方法詳解
延遲任務(wù)(Delayed Task)是指在未來(lái)的某個(gè)時(shí)間點(diǎn),執(zhí)行相應(yīng)的任務(wù),本文為大家整理了三種常見(jiàn)的實(shí)現(xiàn)方法,感興趣的小伙伴可以參考一下2025-04-04使用SpringBoot?+?Redis?實(shí)現(xiàn)接口限流的方式
這篇文章主要介紹了SpringBoot?+?Redis?實(shí)現(xiàn)接口限流,Redis?除了做緩存,還能干很多很多事情:分布式鎖、限流、處理請(qǐng)求接口冪等,文中給大家提到了限流注解的創(chuàng)建方式,需要的朋友可以參考下2022-05-05redis.clients.jedis.exceptions.JedisBusyException無(wú)法處理異常的解決方法
redis.clients.jedis.exceptions.JedisBusyException異常通常不是 Jedis客戶端直接拋出的標(biāo)準(zhǔn)異常,本文就來(lái)介紹一下異常的解決方法,感興趣的可以了解一下2024-05-05利用Redis如何實(shí)現(xiàn)自動(dòng)補(bǔ)全功能
這篇文章主要給大家介紹了關(guān)于如何利用Redis如何實(shí)現(xiàn)自動(dòng)補(bǔ)全功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09redis數(shù)據(jù)一致性之延時(shí)雙刪策略詳解
在使用redis時(shí),需要保持redis和數(shù)據(jù)庫(kù)數(shù)據(jù)的一致性,最流行的解決方案之一就是延時(shí)雙刪策略,今天我們就來(lái)詳細(xì)刨析一下,需要的朋友可以參考下2023-09-09Redis配合SSDB實(shí)現(xiàn)持久化存儲(chǔ)代碼示例
這篇文章主要介紹了Redis配合SSDB實(shí)現(xiàn)持久化存儲(chǔ)代碼示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11