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助手
相关推荐
他是龙5516 小时前
71:Python安全 & 反序列化 & PYC反编译 & 格式化字符串安全2601_956139426 小时前
文体娱媒品牌全案公司哪家强那我掉的头发算什么7 小时前
【面试八股】一篇文章讲清楚JVM面试常考水木流年追梦7 小时前
【python因果库实战27】逆概率加权模型2萧曵 丶7 小时前
MySQL 高频面试题(由浅到深 完整版,面试必背)czlczl200209257 小时前
MySQL 执行引擎:排序与临时表机制深度解析铁皮哥7 小时前
【后端/Agent 开发】给你的项目配置一套 .claude/ 工作流:别再裸用 Claude Code 了!lifewange8 小时前
DBeaver如何安装m0_631529828 小时前
CSS如何利用CSS变量进行渐变色管理_提升渐变配置的灵活性2301_818008448 小时前
数据库模型设计实战:如何正向工程从模型建表_规范化项目开发流程