Redis如何优化大量对象存储_利用Hash结构减少内存碎片占用

Hash比String存对象更省内存,因Hash共享字段名并采用ziplist/hashtable压缩编码,实测省40%--60%;String则重复存储key、引号、逗号等冗余字符。为什么 Hash 比 String 存对象更省内存直接存 JSON 字符串到 String 类型,每个字段都带 key 名、引号、逗号、空格------这些全算内存。而 HASH 把字段名和值分别编码,复用字段名(比如 1000 个用户都有 name、age),底层用 ziplist 或 hashtable 压缩存储,实测能省 40%--60% 内存。关键不是"结构好看",是 Redis 对 HASH 的字段名做了共享前缀和紧凑编码,String 则完全没这层优化。什么时候该用 HASH 而不是 JSON String满足以下任一条件,就该切到 HASH:对象字段固定且数量少(如 user:{id} 含 name/email/status)需要频繁读写单个字段(HGET user:123 name 比 GET user:123 再解析 JSON 快得多)要批量更新几个字段但不想反序列化/序列化整条 JSON(HMSET user:123 name "a" status "active")字段值普遍较短(ziplist 编码生效阈值默认 hash-max-ziplist-entries 512 + hash-max-ziplist-value 64)如果字段名不固定、嵌套深(如 address.city)、或单字段超 64 字节且数量多,ziplist 会退化为 hashtable,优势减弱。必须调的两个配置项:避免 ziplist 过早退化默认配置在字段稍长或稍多时就触发 hashtable,失去压缩优势。上线前务必检查: RedClaw 百度推出的手机端万能AI Agent助手

相关推荐
aqi003 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn4 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵20 小时前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup111 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi001 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵1 天前
用 Python 实现 Take-Away 游戏
python·游戏
copyer_xyf1 天前
Agent 流程编排
后端·python·agent
copyer_xyf1 天前
Agent RAG
后端·python·agent