dubbo rpc序列化

序列化配置

provider

xml 复制代码
<dubbo:service interface="com.example.DemoService" serialization="hessian2" ref="demoService"/>

consumer

xml 复制代码
<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、添加依赖

xml 复制代码
        <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/

相关推荐
齐鲁大虾41 分钟前
如何彻底解决从公网HTTP页面请求私有HTTP资源跨域问题
网络·网络协议·http
g3voip1 小时前
洁净室IP电话机是什么?无尘车间语音通信设备的功能与部署要点
网络·网络协议·tcp/ip
上海云盾第一敬业销售1 小时前
网站安全防护策略与误报处理方案探索
网络协议·web安全·ddos
猫头虎4 小时前
猫头虎AI分享|樱桃键盘Ctrl键失效解决方案:FN+PAUSE 长按10秒恢复出厂设置保姆级教程
网络·网络协议·tcp/ip·计算机外设·键盘·机械键盘·ctrl
network_tester4 小时前
SENT/PSI5传感器TSN集成测试:打通传统传感与未来车载网络的“最后一公里”
数据库·网络协议·tcp/ip·自动驾驶·信息与通信·信号处理·tcpdump
WIZnet4 小时前
W55RP20-EVB-MKR 模块 MicroPython 实战 (11):HTTP 协议与 OneNET 平台数据上云
网络·网络协议·http
IT大白鼠4 小时前
BGP路径选择机制:属性分类、作用解析与选路流程全解
网络·网络协议·华为
北京耐用通信5 小时前
耐达讯自动化NY-N801网关实现Modbus转Profinet协议转换应用案例
人工智能·物联网·网络协议·自动化·信息与通信
酉鬼女又兒6 小时前
零基础入门虚拟局域网VLAN:从广播域问题根源到802.1q帧格式、三大端口类型及实战例题全解析
网络·网络协议·计算机网络·网络安全·职场和发展·智能路由器·求职招聘
VidDown6 小时前
热门短视频平台的视频编码技术解(VidDown)
网络协议·编辑器·音视频·视频编解码·视频