当前位置: 首页 > news >正文

dubbo rpc序列化

序列化配置

provider

<dubbo:service interface="com.example.DemoService" serialization="hessian2" ref="demoService"/>

consumer

<dubbo:reference id="demoService" interface="com.example.DemoService" serialization="hessian2"/>

上述配置中,服务端和消费端serialization属性指定了序列化方式为Hessian2。同样,你可以根据需要选择其他的序列化方式。

需要注意的是,序列化方式的选择应该与服务提供者和消费者之间的兼容性相匹配。如果服务提供者和消费者使用的序列化方式不一致,可能会导致通信失败。因此,在选择序列化方式时,应确保服务提供者和消费者都支持所选的序列化方式。

常用类型

1、Hessian2序列化:Hessian是一种跨语言的高效二进制序列化方式。Dubbo默认启用的序列化方式是阿里修改过的Hessian Lite,而不是原生的Hessian2序列化。

2、Fastjson序列化:Dubbo目前有两种实现,一种是采用的阿里的fastjson库,另一种是采用dubbo中自已实现的简单json库,一般情况下,json这种文本序列化性能不如二进制序列化。

3、Kryo依赖于字节码生成机制(底层使用了ASM库),因此在序列化速度上有一定的优势,但正因如此,其使用也只能限制在基于JVM的语言上其序列化的结果是二进制的byte[],因此像Redis这样可以存储二进制数据的存储引擎可以直接将Kryo序列化出来的数据存进去。

为了避免出现rpc调用出现序列化问题、尽量服务端和消费端使用相同的序列化方式

注意

1、rpc相关的类必须实现 Serializable 接口
2、服务端和消费端使用相同的序列化方式并保持版本一致

Kryo使用

1、添加依赖

        <dependency><groupId>com.esotericsoftware</groupId><artifactId>kryo</artifactId><version>4.0.1</version></dependency><dependency><groupId>de.javakaffee</groupId><artifactId>kryo-serializers</artifactId><version>0.42</version><exclusions><exclusion><groupId>com.esotericsoftware</groupId><artifactId>kryo</artifactId></exclusion></exclusions></dependency>

2、使用springboot项目在配置文件添加如下配置指定序列化方式
dubbo.protocol.serialization=kryo

其他方式大同小异。
参考官网: https://cn.dubbo.apache.org/zh-cn/overview/mannual/java-sdk/reference-manual/serialization/

http://www.lryc.cn/news/292152.html

相关文章:

  • 【C语言】va_list(可变参数处理)
  • 负载均衡下的webshell连接
  • 5-4 D. DS串应用—最长重复子串
  • C语言实现12种排序算法
  • C语言应用实例——贪吃蛇
  • Mac如何设置一位数密码?
  • 运动编辑学习笔记
  • C#小结:ScottPlot 5.0在VS2022桌面开发的应用(以winform为例)
  • Jmeter性能测试: Jmeter 5.6.3 分布式部署
  • 跟着cherno手搓游戏引擎【15】DrawCall的封装
  • Qt实现窗口吸附屏幕边缘 自动收缩
  • shell脚本之免交互
  • Ajax入门与使用
  • 蓝桥杯备战——11.NE555测频
  • 代码随想录算法训练营第三十三天|509. 斐波那契数 ,● 70. 爬楼梯 , 746. 使用最小花费爬楼梯
  • Node.js 文件系统操作指南
  • Kotlin 协程1:深入理解withContext
  • (自用)learnOpenGL学习总结-高级OpenGL-几何着色器
  • 坚持刷题 | 完全二叉树的节点个数
  • K8S网络
  • 【蓝桥杯51单片机入门记录】LED
  • 轻松使用python将PDF转换为图片(成功)
  • 【目标检测】对DETR的简单理解
  • [工具探索]Safari 和 Google Chrome 浏览器内核差异
  • 文本生成高清、连贯视频,谷歌推出时空扩散模型
  • 时隔3年 | 微软 | Windows Server 2025 重磅发布
  • 有趣的css - 动态的毛玻璃背景
  • 桥接模式解析
  • MySQL数据库基础第一篇(SQL通用语法与分类)
  • 【Qt学习笔记】(一)初识Qt