对比 JSON 和 Hessian2 的序列化格式

关于服务通信,我了解到Spring Cloud LoadBalancer 和 Dubbo 的数据传输方式有所不同。它们分别使用不同的协议和技术栈来实现服务之间的通信。

他们两者对比可知:

特性Spring Cloud LoadBalancerDubbo
主要协议HTTP/RESTDubbo 协议(默认),支持 HTTP、Thrift、gRPC 等
序列化格式JSON、XMLHessian2(默认),支持 Protobuf、JSON 等
传输层协议TCP/IP(通过 HTTP/HTTPS)TCP/IP
连接管理短连接(每次请求一个新的连接)长连接(支持连接复用,适合高并发场景)
性能中等,受限于 HTTP 协议的开销高性能,低开销的 RPC 调用,适合高并发和大数据量场景
使用场景微服务架构,轻量级 REST 调用,适合 HTTP/REST 通信高性能、高并发服务调用,复杂服务治理需求

其中序列化格式一个是Json,一个是Hessian2,我对此查询资料做了分析对比

对比总结:

特性JSONHessian2
可读性高,可读性强,便于调试低,二进制格式,不便于调试
语言无关性高,几乎所有语言都支持中等,支持多语言但依赖库支持
性能低,序列化和反序列化速度较慢高,序列化和反序列化速度非常快
数据体积大,包含字段名等额外信息小,二进制格式,数据体积小
类型安全低,类型不严格,可能导致解析错误高,包含类型信息,保证数据一致性
应用场景Web 开发,API 接口,广泛应用高性能 RPC 调用,高并发场景
调试和日志记录容易调试,日志记录友好调试困难,不便于日志记录
安全性中等,依赖于 JSON 解析库的实现高,严格的类型信息,有更好的数据完整性

安全性分析

JSON
  • 优点
    • 广泛支持的安全库:大多数语言都提供了成熟的 JSON 解析库,并且这些库通常已经过安全性验证。
    • 数据验证:可以结合 JSON Schema 进行数据验证,确保数据格式和内容符合预期。
  • 缺点
    • 容易被注入攻击:由于其开放性,JSON 解析容易受到 JSON 注入攻击,如果没有适当的验证和清理,可能会导致安全漏洞。
    • 类型不严格:由于 JSON 数据类型较为松散,容易在传输过程中被篡改,导致安全问题。
Hessian2
  • 优点
    • 类型严格:Hessian2 包含类型信息,能够严格保证数据的一致性和完整性,有助于防止数据篡改。
    • 难以篡改:二进制格式的数据不易被恶意篡改,比文本格式更安全。
  • 缺点
    • 依赖库的安全性:由于 Hessian2 的实现较为复杂,安全性高度依赖于序列化/反序列化库的实现。如果库本身存在漏洞,可能会导致安全问题。
    • 调试困难:二进制格式的数据不便于调试和审计,出现安全问题时不容易排查。

最终建议

选择 JSON 或 Hessian2 主要取决于具体应用场景

  • 如果可读性和跨语言支持是关键:如 Web 开发、API 接口等场景,建议使用 JSON。虽然性能和数据体积上不如 Hessian2,但 JSON 的广泛支持和易用性使其成为默认选择。
  • 如果性能和数据传输效率是关键:如高并发、高性能的 RPC 调用场景,建议使用 Hessian2。虽然复杂度和可读性较差,但其高效的序列化和反序列化性能,以及严格的类型安全,能够满足对性能和数据一致性要求较高的应用。

因此最终结合实际场景决定用Dubbo;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/851207.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

史上最详细四叉树地图不同技术应用和代码详解

四叉树地图在计算机和机器人领域应用的很广,但是初学者可能会发现四叉树地图有各种不同的实现方式,很多在机器人领域不适用或是在计算机存储领域不适用。今天我就讲解下各类四叉树的实现方式和应用场景。 史上最详细四叉树地图不同技术应用和代码详解 本…

vue3+ts webVTT与JSON之前格式互转

vue interface Cue {startTime: stringendTime: stringcontent: string// 可以根据需要添加其他属性,如样式、行号等 } /** desc WebVtt转 JSON */ export function parseWebVTT(vttContent: any): Cue[] {const cues: Cue[] []if (!vttContent) {return []}const …

Bio-Info每日一题:Rosalind-06-Counting Point Mutations

🎉 进入生物信息学的世界,与Rosalind一起探索吧!🧬 Rosalind是一个在线平台,专为学习和实践生物信息学而设计。该平台提供了一系列循序渐进的编程挑战,帮助用户从基础到高级掌握生物信息学知识。无论你是初…

详解MySQL的MVCC机制

多版本并发控制(MVCC,Multi-Version Concurrency Control)是MySQL InnoDB存储引擎用于实现事务隔离和提高并发性能的一种机制。MVCC通过在同一数据的多个版本之间进行管理,允许读写操作并发进行,从而避免了传统锁机制带…

Navicat导入json文件(json文件数据导入到MySQL表中)

天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…

mqttjs发送成功回调

在mqttjs中,发送成功回调可以通过设置client.publish()方法的callback参数来实现。以下是一个示例: javascript const mqtt require(mqtt); const client mqtt.connect(mqtt://test.mosquitto.org); client.on(connect, () > { const topic test…

多目标融合参数搜索

多目标融合 权重分类目人群。 trick normlize 不同Score之间含义、量级和分布差异较大:评分计算的不同部分的意义、范围和分布存在显著差异,这使得直接比较或融合它们的结果变得困难。显式反馈(如点赞率)存在用户间差异&#…

【AI】人工智能(AI)的崛起与未来展望

人工智能(AI)的崛起与未来展望 描述一、AI的基本概念二、AI的发展历程三、AI的应用场景与代码示例四、AI在自动驾驶中的应用五、AI的未来展望 描述 随着科技的飞速发展,人工智能(AI)已经成为当今科技领域的热门话题。…

git拉取合并分支冲突解决

这个错误信息 ! [rejected] release_zfbchk -> dev1 (non-fast-forward) 表示 Git 拒绝执行 git pull 操作,因为远程分支 release_zfbchk 的更新不能直接合并到本地分支 dev1,因为这不是一次快进(fast-forward)合并。 在 Git …

【9】openssl 代码调试

0x01 前言 最近在学习密码学,但是国密算法(SM2,SM3,SM4,SM9)的细节都在openssl项目里,当然一些国际算法也在。想着看下代码执行过程和理论结合起来。中间走了一些弯路,做个笔记。 0x02 openssl安装 一开始认为是不是直接下载好的…

Layui实现下拉多选功能

1、问题概述? 提供源码下载 在项目中有很多地方需要使用到下拉框,并且实现选择多个信息,下面是展示。 支持如下功能: 1、分页 2、主题自定义 3、国际化 4、下拉方向 5、Tips修改等 6、Style自定义样式 7、取值 8、赋值 2、资源准备及测试? 2.1、资源下载

Leetcode 力扣113. 路径总和 II (抖音号:708231408)

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入:root [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum 22 输出&a…

AIGC笔记--Stable Diffusion源码剖析之UNetModel

1--前言 以论文《High-Resolution Image Synthesis with Latent Diffusion Models》 开源的项目为例,剖析Stable Diffusion经典组成部分,巩固学习加深印象。 2--UNetModel 一个可以debug的小demo:SD_UNet​​​​​​​ 以文生图为例&#…

中山大学和字节发布「视频虚拟试穿」扩散模型VITON-DiT,一键生成换装后视频!

视频虚拟试穿技术日益受到关注,然而现有的工作局限于将服装图像转移到姿势和背景简单的视频上,对于随意拍摄的视频则效果不佳。最近,Sora 揭示了 Diffusion Transformer (DiT) 在生成具有真实场景的逼真视频方面的可扩展性,可以说…

Kubernetes入门-大简介

目录 何为微服务 何为云原生 何为编排器 “Kubernetes”这个名字来自希腊语,意思是“舵手”舵手是一个航海/航行术语,指掌舵的人从本质上说,Kubernetes是云原生微服务(cloud-native microservice)应用的编排器(orchestrator) 何为微服务 …

大模型日报2024-06-09

大模型日报 2024-06-09 大模型资讯 Qwen2-72B:拥有72亿参数的先进AI模型 摘要: Qwen团队近日发布了最新突破性成果——Qwen2-72B。这款最先进的语言模型具备72亿参数、支持128K令牌、多语言精通及业界领先性能,展示了显著的技术进步。 OpenAI与Anthropic…

WordPress 高级缓存插件 W3 Total Cache 开启支持 Brotli 压缩算法

今天明月给大家分享一下 WordPress 高级缓存插件 W3 Total Cache 开启支持 Brotli 压缩算法的教程,在撰写【WordPress 高级缓存插件 W3 Total Cache Pro 详细配置教程】一文的时候明月就发现 W3 Total Cache 已经支持 Brotli 压缩算法了,可惜的是在安装完…

ctfshow-web入门-命令执行(web53-web55)

目录 1、web53 2、web54 3、web55 1、web53 这里的代码有点不一样,说一下这两种的区别: (1)直接执行 system($c); system($c);这种方式会直接执行命令 $c 并将命令的输出直接发送到标准输出(通常是浏览器&#xff…

【qsort函数】

前言 我们要学习qsort函数并利用冒泡函数仿照qsort函数 首先我们要了解一下qsort(快速排序) 这是函数的的基本参数 void qsort (void* base, size_t num, size_t size,int (*compar)(const void*,const void*)); 简单解释一下 base:指向…

23.在游戏中按下Home键呼出辅助窗口

上一个内容:22.钩子注入原理 在 22.钩子注入原理 它的代码上进行修改 效果图: 首先在CWndMain.h文件中添加下图红框里的东西 ChangeShowState函数的实现 void CWndMain::ChangeShowState() {UiShow !UiShow;ShowWindow(UiShow); } OnInitDialog函数…