Dubbo3技术一套通之Kryo序列化

前言

前面文章讲解了Dubbo的网络通信的中的通信协议、通信方式与序列化的相关内容,半篇文章将实战带你学习Kryo序列化方式的使用

开发使用

Dubbo在序列化方面提供了良好的开发支持,默认情况下它使用Hessian2作为官方的序列化方案。如果要将它替换为Kryo序列化方案,可以按照以下步骤进行开发

导入依赖

官方默认支持Hessian2序列化,如果要使用Kryo序列化,则需要引入Dubbo提供的拓展依赖-dubbo-serialization-kryo。通过观察该依赖的组织ID可以了解Dubbo的拓展依赖。如需使用其他未支持的序列化方式,可自定义修改这个模块中的代码。

xml 复制代码
<dependency>
    <groupId>org.apache.dubbo.extensions</groupId>
    <artifactId>dubbo-serialization-kryo</artifactId>
    <version>1.0.1</version>
</dependency>

Provider设置

在引入kryo依赖后,我们需要在provider端进行设置即可,如下针对Spring配置文件与SpringBoot分别配置

Spring配置文件

下面是使用Spring配置文件对Dubbo通信部分的配置示例。在这个配置中,我们采用了dubbo协议,服务端端口从20880开始递增分配,这有助于避免端口冲突问题。此外,我们还选择了Kryo作为序列化方式,以提高数据传输效率

xml 复制代码
<dubbo:protocol name="dubbo" port="-1" serialization="kryo"/>

SpringBoot

如下是SpringBoot对于网络通信、序列化这块的配置

yml 复制代码
dubbo:
  protocol:
    name: dubbo
    port: -1
    serialization: kryo

Consumer设置

上面我们已经对provider端配置完成并且顺利启动了服务,接下来我们将在consumer端进行配置发起rpc调用。同样对Spring配置文件和SpringBoot进行配置

Spring配置文件

xml 复制代码
<dubbo:reference interface="com.aomsir.service.UserService" id="userService" url="dubbo://192.168.212.1:20880/com.aomsir.service.UserService?serialization=kryo" />

SpringBoot

将调用地址以注解参数的方式进行配置

java 复制代码
@DubboReference(url = "dubbo://192.168.212.1:20880/com.aomsir.service.UserService?serialization=kryo")
private UserService userService;

总结

上述便是将Dubbo 3程序替换Kryo序列化的详细使用方法,替换过程相对简单,只需要导入必要的依赖并稍作配置调整即可完成。然而,我们也需要从更深层次的角度来理解这一过程,例如Dubbo为序列化所保留的扩展槽位以及其可扩展性

参考文献

相关推荐
不爱编程的小陈1 小时前
事务的进化:从MySQL单机事务到TiDB分布式事务的探究
分布式·mysql·tidb
それども7 小时前
怎么理解TCP的状态
java·网络·网络协议·tcp/ip·dubbo
Java 码思客9 小时前
【Redis分布式缓存实战】第4章 单机Redis部署、配置与基础优化
redis·分布式·缓存
卷毛迷你猪9 小时前
快速实验篇(A3)基于 Hive 的气象数据数仓构建与干旱指标初步分析
大数据·hadoop·分布式
卷毛迷你猪9 小时前
快速实验篇(A4)Hive 数据仓库进阶:全站点干旱事件识别与多维统计分析
数据仓库·hive·hadoop·分布式
RingWu10 小时前
高并发三板斧-异步
分布式·微服务·架构
Aaswk10 小时前
计算机网络概述
网络·网络协议·tcp/ip·计算机网络·http·dubbo
搞科研的小刘选手20 小时前
【中山大学主办】第六届计算机科学与区块链国际学术会议(CCSB 2026)
分布式·神经网络·计算机视觉·区块链·计算机科学·共识算法·自然语言
小饼干在学嘎瓦21 小时前
本地缓存和分布式缓存如何选择?
分布式·缓存
XLYcmy1 天前
全链路验证测试系统:一个针对智能代理(Agent)系统全链路能力的自动化验证脚本
分布式·python·http·网络安全·ai·llm·agent