首页 游戏 软件 资讯 排行榜 专题
首页
数据库
Redis String存储序列化对象_对比JSON与Protobuf性能差距

Redis String存储序列化对象_对比JSON与Protobuf性能差距

热心网友
13
转载
2026-04-24

Redis String存对象,JSON和Protobuf谁更快?

开门见山,先说结论:在绝大多数性能测试中,Protobuf的序列化与反序列化速度普遍比JSON快上2到5倍,同时内存占用能降低30%到60%。不过,这个优势有个重要前提:你的对象结构得足够稳定,并且已经预定义了schema。如果只是临时存个配置,或者调试时随手扔个Map进去,那JSON反而更省事,没必要硬上Protobuf。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

Protobuf序列化+反序列化速度普遍比JSON快2–5倍,内存占用低30%–60%,但需结构稳定且有预定义schema;临时配置或调试用JSON更省事。

Redis String存储序列化对象_对比JSON与Protobuf性能差距

json.dumps() vs protobuf.SerializeToString() 实测差异点

光说理论不够直观,来看一个Python环境下的实测。使用redis-py库,存储一个包含10个字段的用户对象(其中嵌套了地址信息和时间戳),反复压测10万次,结果差异非常明显:

  • 使用json.dumps(),平均每次耗时约85微秒,生成的字符串平均长度在320字节左右。
  • 换成protobuf.SerializeToString(),平均耗时骤降至约22微秒,生成的字节流平均长度仅为126字节。
  • 反序列化的差距则更为悬殊。JSON需要经历完整的解析和类型推断过程,而Protobuf直接按照预定义的schema填充字段即可,速度通常能快上4倍以上。
  • 这里有个细节值得注意:json.dumps()默认无法处理datetime对象,直接使用会抛出TypeError;而Protobuf的timestamp字段必须使用google.protobuf.timestamp_pb2.Timestamp进行转换,否则写入同样会失败。

Redis里存Protobuf要注意的三个硬限制

Protobuf性能虽好,但把它存进Redis时,有几个边界条件必须心里有数。Protobuf本身并不校验数据合法性,而Redis String又是一个纯粹的字节容器,问题往往就出在这两者的结合部:

  • 必须用bytes类型写入。正确的做法是r.set(“user:123”, pb_data),其中pb_data已经是字节流。如果你试图r.set(“user:123”, pb_data.decode()),大概率会触发UnicodeDecodeError
  • 没有自动的版本兼容降级机制。假设你的消息结构从v1升级到v2,增加了一个新字段,那么还在使用v1旧schema的客户端在反序列化时,会直接静默丢弃这个新字段。相比之下,JSON至少能读出所有的key,只是旧代码里没有定义对应的字段罢了。
  • Redis不存储类型元信息。当你执行GET user:123,返回的是一串原始的字节。你必须在代码层面自己记住,这个key背后存的是UserProto还是OrderProto。一个实用的建议是在key命名中带上前缀,例如proto:user:123

什么时候该坚持用 JSON?

技术选型从来都是权衡的艺术,并非所有场景都适合换上Protobuf。尤其是在开发节奏快、数据结构频繁变动,或者需要人工直接查看Redis数据的场景下,JSON的优势就体现出来了:

  • 调试与可读性:在调试阶段,用redis-cli GET user:123直接查看值,JSON是人类可读的明文,而Protobuf则是一堆乱码——除非你事先安装了protoc并用--decode_raw来解码。
  • 前端或边缘设备直连:在一些边缘网关或前端直连Redis的特殊架构中,需要直接解析数据。JSON是Ja vaScript的天然支持,开箱即用;而Protobuf则需要额外引入解码库和逻辑。
  • 处理动态结构:当对象字段类型动态变化,比如value可能是dictlist的混合嵌套时,用Protobuf实现会非常棘手,需要设计oneof或使用Any类型,复杂度直线上升。而JSON一行json.dumps(obj, default=str)就能轻松搞定。

说到底,Protobuf的核心优势在于服务间高频、结构固定、对延迟敏感的通信场景。把它用作Redis的序列化工具,只是其能力的一个应用侧面,千万别让对序列化性能的极致追求,反过来绑架了业务本该有的灵活迭代节奏。

来源:https://www.php.cn/faq/2336302.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

MongoDB如何实现对敏感字段的写前校验_配置JSONSchema验证器
数据库
MongoDB如何实现对敏感字段的写前校验_配置JSONSchema验证器

MongoDB如何实现对敏感字段的写前校验 在数据安全领域,服务端校验从来不是一道可选题,而是必答题。MongoDB的JSON Schema验证机制,其定位正是如此——它并非锦上添花的装饰,而是确保数据完整性的最后一道、也是最坚实的兜底防线。原因很简单:无论应用层的校验逻辑写得多么严密,总存在被绕过

热心网友
04.20
Generate JSON
AI
Generate JSON

Generate JSON是什么 在数据驱动的开发世界里,JSON格式几乎无处不在。但手动构建和验证复杂的数据结构,常常既耗时又容易出错。这时候,一个叫做Generate JSON的AI工具走进了视野。它的定位很明确:致力于帮助开发者和数据分析师快速、准确地生成所需的JSON数据。本质上,它通过自动

热心网友
04.20
Entity Framework Core 7如何映射Oracle的JSON列
数据库
Entity Framework Core 7如何映射Oracle的JSON列

EF Core 7 如何高效处理 Oracle JSON 数据:最佳实践与避坑指南 EF Core 7 暂不支持 Oracle JSON 类型的直接映射 在 EF Core 7 中直接映射 Oracle 数据库的 JSON 列会遇到技术限制。当前版本的 EF Core 7 并未内置对 Oracle

热心网友
04.19
mysql如何备份JSON格式数据_8.0版本JSON字段备份注意事项
数据库
mysql如何备份JSON格式数据_8.0版本JSON字段备份注意事项

MySQL JSON字段备份与还原:避开那些“看起来对”的坑 当需要备份MySQL数据库中的JSON字段时,许多开发者会下意识地认为使用mysqldump命令即可轻松完成。然而,实际操作中隐藏着不少细节,若处理不当,备份文件看似正常,但在数据还原时却可能遭遇数据损坏或解析错误。本文将深入剖析MySQ

热心网友
04.19
Go语言怎么解析JSON_Go语言json.Unmarshal教程【高效】
编程语言
Go语言怎么解析JSON_Go语言json.Unmarshal教程【高效】

Go语言JSON解析全攻略:json Unmarshal高效使用教程 在Go语言开发中,JSON数据的解析与序列化是高频操作,而json Unmarshal函数是实现这一功能的核心工具。然而,许多开发者在实际使用中会遇到一个典型问题:函数明明返回了nil错误,表示解析过程“成功”,但目标结构体中的字

热心网友
04.18

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

PromptLayer
AI
PromptLayer

PromptLayer是什么 如果说构建AI应用是一场精巧的协作工程,那么Prompt(提示词)往往是其中最关键的“暗物质”。它决定了模型输出的质量,却常常散落在代码的各个角落,难以管理。PromptLayer的出现,就是专门为了解决这个痛点而生。它是一款专为Prompt工程设计的AI工具,核心目标

热心网友
04.24
Automix AI
AI
Automix AI

Automix AI是什么 在当下的就业市场,一份出色的简历和从容的面试表现,几乎成了每个求职者的“硬通货”。而这就引出了我们今天的主角——Automix AI。简单来说,这是一款由Automix团队精心打造的AI智能工具,它的核心使命就是帮助求职者打磨简历、锤炼面试技巧,从而在激烈竞争中脱颖而出。

热心网友
04.24
ProMind AI
AI
ProMind AI

ProMind AI是什么 在众多AI工具中,有一款产品正悄然成为专业工作者的得力搭档——它就是ProMind AI。简单来说,这是一款专为“效率”而生的AI助手,目标直指需要应对高复杂度任务的专业人群,比如内容创作者、营销人、工程师和产品经理。它的核心使命很明确:帮你把想法快速落地,无论是生成一段

热心网友
04.24
伊朗副总统称将严厉回击对伊朗能源设施的袭击
web3.0
伊朗副总统称将严厉回击对伊朗能源设施的袭击

伊朗副总统警告:任何对伊能源设施的袭击将招致严厉升级回击 4月24日,伊朗方面释放了明确且强硬的信号。副总统伊斯梅尔·萨加布·伊斯法哈尼公开表示,伊朗已准备好严厉回击任何针对其能源设施的袭击。这番话,无疑给当前紧张的地区局势又增添了一层清晰的注脚。 在伊朗埃斯拉姆沙赫尔举行的一次集会上,伊斯法哈尼的

热心网友
04.24
WriteCap
AI
WriteCap

WriteCap是什么 如果创作社交媒体内容时,你曾为想一句点睛的配文而绞尽脑汁,那么你对WriteCap的出现可能就不会感到陌生。简单来说,这是一款专门为解此困境而生的AI工具。它背后的开发团队,瞄准的正是社交媒体内容创作者、品牌营销人员乃至普通用户的日常痛点——如何让每一段分享都更抓人眼球。它的

热心网友
04.24