共计 1676 个字符,预计需要花费 5 分钟才能阅读完成。
spring-boot-starter-grpc 内置序列化方式说明
sofa-hessian(默认)
Github 地址:https://github.com/alipay/sof…
基本说明:Hessian 是一个性能较优且兼容性较好的二进制序列化协议。SOFA-Hessian 基于原生 Hessian v3.1.3 进行改进,目前已经蚂蚁金服内部稳定运行多年。
优点:支持复杂的 Java 对象的序列化
缺点:
- 需要序列化 / 反序列化的对象必须实现
java.io.Serializable
protostuff
Github 地址:https://github.com/protostuff…
基本说明: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 并发用户
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,如有疑问或者更优秀的方案,欢迎联系作者试用!
● 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 发布!