不服不行啊!大牛确实把SpringCloud集成Dubbo给一次性讲透了

简介: Spring Cloud集成Dubbo目前Dubbo在国内还是有较多公司在使用的,一方面是因为Dubbo作为阿里巴巴开源的一个SOA服务治理解决方案,在国内发展较早,有比较好的先发优势;另一方面是因为在国内很多工程师对Dubbo框架都比较熟悉,有比较完善的文档介绍和实例;还有,Dubbo框架的性能优势和基于SPI的扩展机制也是Dubbo的优势所在。

Spring Cloud集成Dubbo


目前Dubbo在国内还是有较多公司在使用的,一方面是因为Dubbo作为阿里巴巴开源的一个SOA服务治理解决方案,在国内发展较早,有比较好的先发优势;另一方面是因为在国内很多工程师对Dubbo框架都比较熟悉,有比较完善的文档介绍和实例;还有,Dubbo框架的性能优势和基于SPI的扩展机制也是Dubbo的优势所在。

image.png

然而,现在很多人也拿Dubbo与Spring Cloud做比较,其实Dubbo本质上是一个RPC框架,实现了SOA架构下的微服务治理,而SpringCloud下有众多子项目,分别覆盖了微服务开发的各个方面,所以在一定程度上讲,Dubbo可以算是Spring Cloud的子集。

在Spring Cloud构建的微服务系统中,大多数开发者都使用官方提供的Feign组件来进行内部服务通信,这种声明式的HTTP客户端使用起来非常简洁、方便、优雅。但是在使用Feign消费服务的时候,相比Dubbo这种RPC框架而言,性能较低。所以基于Dubbo RPC方式的服务集成的交互方式也是Spring Cloud体系的一个重要补充。


提供Dubbo服务


下面通过一个简单的示例演示如何将Dubbo接入Spring Cloud。我们假设存在一个Dubbo RPC API,由服务提供者为服务消费者暴露接口:

image.png

首先,添加依赖:

image.png

然后,在application.yml中添加Dubbo的相关配置信息,示例配置如下:

image.png


接下来,在SpringBoot应用上添加@EnableDubboConfiguration , 表 示 要 开 启 Dubbo 功 能 ( DubboProvider服务可以使用或者不使用Web容器)。

image.png

编 写 你 的 Dubbo 服 务 , 只 需 要 在 要 发 布 的 服 务 上 添 加@Service(

importcom.alibaba.dubbo.config.annotation.Service ) 注 解 , 其 中interfaceClass属性表示要发布服务的接口声明。

image.png

启动你的Spring Boot应用,观察控制台,你可以看到Dubbo启动的相关信息。


消费Dubbo服务


首先,添加依赖:

image.png

其次,在application.properties中添加Dubbo的相关配置信息,示例如下:

image.png

然后,开启@EnableDubboConfiguration:

image.png

最后,通过@Reference注入需要使用的interface:

image.png


Spring Boot与Dubbo集成


上面的示例适用于新建项目,可以很方便地将Dubbo集成到SpringBoot应用,相比传统的Dubbo基于XML的配置方式,Spring Boot遵循“约定优于配置”理念,只需要加入几行注解就可以完成工作,而对于已经使用传统方式而非Spring Boot方式接入Dubbo框架实现的系统,如何通过增加一些代码就可以将Dubbo服务纳入Spring Cloud的体系是另外一个重要的课题。


● 思路一:将Dubbo服务的对外接口暴露为REST API

对于Dubbo服务提供者来说,可以通过@RestController封装服务端代码,对外暴露REST API。使用时,我们只需要在调用端的Service中注入InvokeRemoteService就可以像调用本地方法一样进行远程调用:

image.png


对于Dubbo服务的消费者,你可以借助Spring Cloud中的Feign作为HTTP REST的调用接口,对于Dubbo服务,你可以向原来对外提供的Service interface类加入@FeignClient注解,支持外部调用,将对外暴露接口加上@RequestMapping或者@RestController注解,并且把接口改成REST风格的,代码如下:

image.png


上面的代码中我们声明了一个HTTP“模板”,这个“模板”有一个方法声明findByGroupId,可以通过注解定义这个方法需要发起的HTTP请求信息(注解与Spring MVC完全相同)。


● 思路二:将Spring Cloud服务Dubbo化

这一改造的思路是替换Spring Cloud的Feign的底层调用协议,将原本使用HTTP Client的处理请求转交给Dubbo RPC来处理,同时将原本对外提供的REST API转换为Dubbo的服务,可以参考GitHub上的Dubbo开源项目(dubbo-spring-boot-project)。

首先,加入下面的Maven依赖:

image.png


然后,实现RPC接口定义:

image.png

服务端可以支持多协议发布服务:

image.png

接着,我们完成对消费端的实现:

image.png


application.properties中添加Dubbo的版本信息和客户端超时信息,向启动类添加@Enable-DubboConfiguration注解,这里我们配置的这些参数会在项目启动时被加载到DubboProperties类中。

image.png


最后,实现Dubbo自动化配置:

image.png

image.png


上 面 我 们 实 现 了 提 供 Dubbo 的 @Service 注 解 服 务 。 在DubboAutoConfiguration配置类中启动Bean,当配置文件中的前缀以“dubbo”开始时,会注入相关配置并完成初始化,然后获取所有加了@Service注解的类,使用反射生成代理类。当我们使用HTTP请求这些由@Service注解的类的方法时,它会将HTTP请求转换成Dubbo请求,调用这个代理类将调用结果返回。

相关文章
|
18天前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
44 2
|
1月前
|
存储 数据可视化 Java
基于MicrometerTracing门面和Zipkin实现集成springcloud2023的服务追踪
Sleuth将会停止维护,Sleuth最新版本也只支持springboot2。作为替代可以使用MicrometerTracing在微服务中作为服务追踪的工具。
84 1
|
3月前
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
定时任务在企业应用中至关重要,常用于异步数据处理、自动化运维等场景。在单体应用中,利用Java的`java.util.Timer`或Spring的`@Scheduled`即可轻松实现。然而,进入微服务架构后,任务可能因多节点并发执行而重复。Spring Cloud Alibaba为此发布了Scheduling模块,提供轻量级、高可用的分布式定时任务解决方案,支持防重复执行、分片运行等功能,并可通过`spring-cloud-starter-alibaba-schedulerx`快速集成。用户可选择基于阿里云SchedulerX托管服务或采用本地开源方案(如ShedLock)
111 1
|
3月前
|
Dubbo Java 应用服务中间件
💥Spring Cloud Dubbo火爆来袭!微服务通信的终极利器,你知道它有多强大吗?🔥
【8月更文挑战第29天】随着信息技术的发展,微服务架构成为企业应用开发的主流模式,而高效的微服务通信至关重要。Spring Cloud Dubbo通过整合Dubbo与Spring Cloud的优势,提供高性能RPC通信及丰富的生态支持,包括服务注册与发现、负载均衡和容错机制等,简化了服务调用管理并支持多种通信协议,提升了系统的可伸缩性和稳定性,成为微服务通信领域的优选方案。开发者仅需关注业务逻辑,而无需过多关心底层通信细节,使得Spring Cloud Dubbo在未来微服务开发中将更加受到青睐。
82 0
|
4月前
|
NoSQL Java Nacos
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
127 3
|
21天前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
4月前
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
Spring Cloud Alibaba 发布了 Scheduling 任务调度模块 [#3732]提供了一套开源、轻量级、高可用的定时任务解决方案,帮助您快速开发微服务体系下的分布式定时任务。
14886 28
|
4月前
|
Java API 开发工具
Spring Boot与Spring Cloud Config的集成
Spring Boot与Spring Cloud Config的集成
|
4月前
|
监控 Dubbo 应用服务中间件
通用快照方案问题之Sentinel与SpringCloud和Dubbo的整合如何解决
通用快照方案问题之Sentinel与SpringCloud和Dubbo的整合如何解决
45 0
|
6月前
|
Dubbo Java 应用服务中间件
微服务学习 | Springboot整合Dubbo+Nacos实现RPC调用
微服务学习 | Springboot整合Dubbo+Nacos实现RPC调用