SpringCloudAlibaba(五):SpringCloudAlibaba+Dubbo实践

2024-06-11 03:32

本文主要是介绍SpringCloudAlibaba(五):SpringCloudAlibaba+Dubbo实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SpringCloud与Dubbo两个框架一直以来都被用来作为两种框架进行比较,其实对于两者之间进行比较是不公平的。SpringCloud可以说是一套完整的解决方案而Dubbo其实只是一种RPC和服务治理的实现方案。

Dubbo一直以来在国内有较多的使用,虽然阿里中间有一段时间没有进行维护,但是受众群体还是比较多的。同时在阿里不再维护的那段时期也由当当维护的DubboX推出。但是Dubbo的相关周边组件也依然不是那么的完善。

SpringCloud与Dubbo的整合方案不是那么的完善,相对来说整合的都比较‘丑’。Dubbo的注册中心是Zookeeper而SpringCloud一开始是不支持Zookeeper作为注册中心的。所以在大部分的公司架构中都是二者之间取其一。

SpringCloudAlibaba的出现解决了这样的问题,SpringCloudAlibaba与Dubbo都选用Nacos作为服务的注册中心,并且可以类似于传统项目的SpringCloud项目一样使用Feign进行消费。今天就尝试一下使用Dubbo连接Nacos注册中心。

开始之前

可能之前写过Dubbo的同学比较了解,Dubbo的服务提供方基本需要支持两个项目,「api」「provider」「api」负责定义服务所提供的相关接口,以供消费方进行依赖。 「provider」则提供相关接口的具体实现。
例如:

以上的结构是遵守了几年的一个规范,提供的相关接口由api项目负责定义,provider负责进行实现,consumer则依赖相关api进行服务的调用。下面进行分步骤的实现。

api 定义服务接口

「IHelloService.java」

public interface IHelloService {String hello(String name);}

privider构建服务提供方

  • 第一步:构建SpringBoot项目,引入SpringCloudAlibaba Nacos Dubbo相关依赖。同时也需要引入刚才的api项目。

<dependencies><dependency><groupId>top.anydata.products.web</groupId><artifactId>nacos-discovery-dubbo-api</artifactId><version>0.0.1-SNAPSHOT</version><scope>compile</scope></dependency><!--com.alibaba.cloud为毕业版本,org.springfremework.cloud为孵化版本--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-dubbo</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--必须包含,否则会报错--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency>
</dependencies>
  • 第二步:实现api项目中定义的接口 「HelloServiceImpl.java」

@Service
public class HelloServiceImpl implements IHelloService {@Overridepublic String hello(String name) {return "Hello:"+name;}}

「WARN: 这里的@Service注解不是springframework的而是org.apache.dubbo.config.annotation.Service注解」

  • 第三步:配置文件

server:port: 8080
spring:application:name: nacos-dubbo-providermain:allow-bean-definition-overriding: truecloud:nacos:discovery:enabled: trueregister-enabled: trueserver-addr: localhost:8848profiles:active: true
dubbo:scan:base-packages: top.anydata.products.web.example.nacos_discovery_dubbo_provider.serviceprotocol:name: dubboport: -1registry:address: spring-cloud://localhostapplication:qos-enable: truecloud:subscribed-services: /

配置nacos注册中心相关,同时增加dubbo相关的配置信息。其中 「scan」 表示要扫描的dubbo基础包。

  • 创建SpringBootApplication启动类与启动验证 「NacosDubboProviderApplication.java」

@SpringBootApplication
@EnableDiscoveryClient
public class NacosDubboProviderApplication {public static void main(String[] args) {SpringApplication.run(NacosDubboProviderApplication.class,args);}}

「启动」

启动成功后在Nacos服务列表中即可看到入上服务。

consumer服务消费方

第一步:构建服务消费调用项目,pom.xml 所需的依赖与 provider一致。

第二步:创建Controller进行服务消费

「HelloController.java」

@RestController
public class HelloController {@ReferenceIHelloService helloService;@RequestMapping(value = "hello")public String hello(String name){return helloService.hello(name);}}

「WARN: @Reference 是org.apache.dubbo.config.annotation.Reference 有较多的参数配置可选,例如check=true校验服务是否健康等」

第三步:Dubbo相关配置

server:port: 8081application:name: nacos-dubbo-consumermain:allow-bean-definition-overriding: truecloud:nacos:discovery:enabled: trueregister-enabled: trueserver-addr: localhost:8848
spring:application:name: nacos-dubbo-consumer
dubbo:registry:address: spring-cloud://localhostcloud:subscribed-services: nacos-dubbo-providerapplication:qos-enable: false

「WARN:此处 dubbo.cloud.subscribed-services为调用的服务,配置为服务的注册名称。可以在Nacos中查看」

第四步:创建「NacosDubboConsumerApplication」类并启动消费

「NacosDubboConsumerApplication.java」

@SpringBootApplication
@EnableDiscoveryClient
public class NacosDubboConsumerApplication {public static void main(String[] args) {SpringApplication.run(NacosDubboConsumerApplication.class,args);}}

启动成功后仍然使用postman进行测试。

结论

通过以上的测试,可以看到SpringCloud与Dubbo使用Nacos注册中心来实现还是非常简单的,Dubbo 的RPC性能优势还是非常重要的。同时仍可以享受SpringCloud的各种便利。SpringCloudAlibaba提供的整合方案能够融合SpringCloud与Dubbo的各种优势,同时也便于原有SpringCloud与Dubbo用户的迁移。

「本篇源码示例:」

https://github.com/CainGao/SpringCloudAlibabaExample  

这篇关于SpringCloudAlibaba(五):SpringCloudAlibaba+Dubbo实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050084

相关文章

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

java中XML的使用全过程

《java中XML的使用全过程》:本文主要介绍java中XML的使用全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录什么是XML特点XML作用XML的编写语法基本语法特殊字符编写约束XML的书写格式DTD文档schema文档解析XML的方法​​DOM解析XM

Java 的 Condition 接口与等待通知机制详解

《Java的Condition接口与等待通知机制详解》在Java并发编程里,实现线程间的协作与同步是极为关键的任务,本文将深入探究Condition接口及其背后的等待通知机制,感兴趣的朋友一起看... 目录一、引言二、Condition 接口概述2.1 基本概念2.2 与 Object 类等待通知方法的区别

SpringBoot项目中Redis存储Session对象序列化处理

《SpringBoot项目中Redis存储Session对象序列化处理》在SpringBoot项目中使用Redis存储Session时,对象的序列化和反序列化是关键步骤,下面我们就来讲讲如何在Spri... 目录一、为什么需要序列化处理二、Spring Boot 集成 Redis 存储 Session2.1

使用Java实现Navicat密码的加密与解密的代码解析

《使用Java实现Navicat密码的加密与解密的代码解析》:本文主要介绍使用Java实现Navicat密码的加密与解密,通过本文,我们了解了如何利用Java语言实现对Navicat保存的数据库密... 目录一、背景介绍二、环境准备三、代码解析四、核心代码展示五、总结在日常开发过程中,我们有时需要处理各种软

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、