Redis 统计每个数据类型中占用内存最多的前 N 个 bigkey
import redis
def find_bigkeys(host='localhost', port=6379, db=0, n=10):
r = redis.Redis(host=host, port=port, db=0)
bigkeys = {}
type_memory_dict = {}
for key in r.scan_iter("*"):
key_type = r.type(key).decode()
memory_usage = r.memory_usage(key)
if key_type not in type_memory_dict:
type_memory_dict[key_type] = []
type_memory_dict[key_type].append((key, memory_usage))
for key_type, key_memory_list in type_memory_dict.items():
key_memory_list.sort(key=lambda x: x[1], reverse=True)
bigkeys[key_type] = key_memory_list[:n]
return bigkeys
if __name__ == "__main__":
bigkeys = find_bigkeys()
for key_type, bigkey_list in bigkeys.items():
print(f"数据类型: {key_type}")
for key, memory_usage in bigkey_list:
print(f"键: {key}, 内存占用: {memory_usage} 字节")
#!/bin/bash
REDIS_HOST="localhost"
REDIS_PORT=6379
N=10
declare -A type_files
cursor=0
while true; do
result=$(redis-cli -h $REDIS_HOST -p $REDIS_PORT SCAN $cursor)
cursor=$(echo $result | awk '{print $1}')
keys=$(echo $result | awk '{$1=""; print $0}' | tr ' ' '\n')
for key in $keys; do
key_type=$(redis-cli -h $REDIS_HOST -p $REDIS_PORT TYPE $key)
memory_usage=$(redis-cli -h $REDIS_HOST -p $REDIS_PORT MEMORY USAGE $key)
if [ ! -f "${type_files[$key_type]}" ]; then
type_files[$key_type]="/tmp/redis_bigkeys_${key_type}.tmp"
> "${type_files[$key_type]}"
fi
echo "$key $memory_usage" >> "${type_files[$key_type]}"
done
if [ $cursor -eq 0 ]; then
break
fi
done
for key_type in "${!type_files[@]}"; do
file="${type_files[$key_type]}"
echo "数据类型: $key_type"
sort -k2 -nr $file | head -n $N | while read key memory; do
echo "键: $key, 内存占用: $memory 字节"
done
rm $file
done