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

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

sofa-hessian(默认)java

Github 地址:https://github.com/alipay/sof...git

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

优势:支持复杂的 Java 对象的序列化面试

缺点:spring

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

protostuff编程

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

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

优势:速度快,内存占用少缓存

缺点:并发

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

fastjson

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

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

优势:跨语言支持方便

缺点:

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

性能测试报告

测试代码地址:https://github.com/ChinaSilen...

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

10万次请求 20并发用户

img

10万次请求 50并发用户

img

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 ,若有疑问或者更优秀的方案,欢迎联系做者试用!

Spring Boot 2 集成log4j2日志框架

Java面试通关要点汇总集之核心篇参考答案

Java面试通关要点汇总集之框架篇参考答案

Spring Security 实战干货:如何保护用户密码

Spring Boot RabbitMQ - 优先级队列

可见性有序性,Happens-before来搞定

Java单元测试之JUnit 5快速上手

高薪必备的一些Spring Boot高级面试题

Spring Boot 2.x 中的 Actuator

下一代应用监控指标采集器Prometheus核心介绍

Spring中@Async注解实现“方法”的异步调用

学并发编程,透彻理解这三个核心是关键

缓存抽象层Spring cache实战操做

简述设计模式原则

并发Bug之源有三,请睁大眼睛看清它们

责任链设计模式讲解

Java Web 面试中关于Spring MVC的必问题,不收藏血亏!

Micronaut 微服务中使用 Kafka

微服务网关除了zuul、spring cloud gateway还有更出色的

RSocket——Http协议的替代者

java中的数字以及如何判断字符串是否是数字

学好Spring Security 和Apache Shiro你须要具有这些条件

原文连接:https://mp.weixin.qq.com/s/oI...

后期更多猛料放出,关注 spring4all 公众号关注实时动态:

本文由博客一文多发平台 OpenWrite 发布!
相关文章
相关标签/搜索