前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring-boot-starter-grpc 不同序列化方式性能测试及选型

spring-boot-starter-grpc 不同序列化方式性能测试及选型

作者头像
轻量级云原生架构实验室
发布2018-09-27 10:11:00
1.6K0
发布2018-09-27 10:11:00
举报
文章被收录于专栏:轻量级微服务

spring-boot-starter-grpc 内置序列化方式说明

sofa-hessian(默认)

Github 地址:https://github.com/alipay/sofa-hessian

基本说明:Hessian 是一个性能较优且兼容性较好的二进制序列化协议。SOFA-Hessian 基于原生 Hessian v3.1.3 进行改进,目前已经蚂蚁金服内部稳定运行多年。

优点:支持复杂的 Java 对象的序列化

缺点:

  • 需要序列化/反序列化的对象必须实现 java.io.Serializable

protostuff

Github 地址:https://github.com/protostuff/protostuff

基本说明:protostuff 基于 Google protobuf,但是提供了更多的功能和更简易的用法。其中,protostuff-runtime 实现了无需预编译对 Java bean进行protobuf 序列化/反序列化的能力。protostuff-runtime 的局限是序列化前需预先传入 schema,反序列化不负责对象的创建只负责复制,因而必须提供默认构造函数。此外,protostuff 还可以按照 protobuf 的配置序列化成 json/yaml/xml 等格式。

优点:速度快,内存占用少

缺点:

  • 类中字段顺序需一致(不利于字段变更)
  • 空集合会被反序列化为 NULL

fastjson

Github 地址:https://github.com/alibaba/fastjson

基本说明:Fastjson 是一个 Java 库,可用于将 Java 对象转换为其 JSON 表示。它还可用于将JSON字符串转换为等效的Java对象。Fastjson 可以处理任意 Java 对象,包括您源代码中的预先不存在的对象。

优点:跨语言支持方便

缺点:

  • Object 对象会被反序列化为 JSONObject ,不优雅
  • 占用内存多

性能测试报告

测试代码地址:https://github.com/ChinaSilence/spring-boot-starter-grpc/tree/master/test

Gatling 官方文档地址:https://gatling.io/docs/3.0/

10万次请求 20并发用户

10万次请求 50并发用户

10万次请求 100并发用户

10万次请求,耗时统计:

20 并发

50 并发

100 并发

本地调用

31s

32s

30s

sofa-hessian

58s

65s

65s

proto-stuff

57s

63s

58s

fastjson

59s

62s

57s

从上述测试结果来看,不同序列化方式的耗时差距并不是很大,综合考虑性能、可维护性、简便性,默认使用 sofa-hessian ,如有疑问或者更优秀的方案,欢迎联系作者试用!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.09.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • spring-boot-starter-grpc 内置序列化方式说明
  • 性能测试报告
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档