网站首页 > 文章精选 正文
Spring Cloud集成Dubbo
目前Dubbo在国内还是有较多公司在使用的,一方面是因为Dubbo作为阿里巴巴开源的一个SOA服务治理解决方案,在国内发展较早,有比较好的先发优势;另一方面是因为在国内很多工程师对Dubbo框架都比较熟悉,有比较完善的文档介绍和实例;还有,Dubbo框架的性能优势和基于SPI的扩展机制也是Dubbo的优势所在。
然而,现在很多人也拿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,由服务提供者为服务消费者暴露接口:
首先,添加依赖:
然后,在application.yml中添加Dubbo的相关配置信息,示例配置如下:
接下来,在SpringBoot应用上添加@EnableDubboConfiguration , 表 示 要 开 启 Dubbo 功 能 ( DubboProvider服务可以使用或者不使用Web容器)。
编 写 你 的 Dubbo 服 务 , 只 需 要 在 要 发 布 的 服 务 上 添 加@Service(
importcom.alibaba.dubbo.config.annotation.Service ) 注 解 , 其 中interfaceClass属性表示要发布服务的接口声明。
启动你的Spring Boot应用,观察控制台,你可以看到Dubbo启动的相关信息。
消费Dubbo服务
首先,添加依赖:
其次,在application.properties中添加Dubbo的相关配置信息,示例如下:
然后,开启@EnableDubboConfiguration:
最后,通过@Reference注入需要使用的interface:
Spring Boot与Dubbo集成
上面的示例适用于新建项目,可以很方便地将Dubbo集成到SpringBoot应用,相比传统的Dubbo基于XML的配置方式,Spring Boot遵循“约定优于配置”理念,只需要加入几行注解就可以完成工作,而对于已经使用传统方式而非Spring Boot方式接入Dubbo框架实现的系统,如何通过增加一些代码就可以将Dubbo服务纳入Spring Cloud的体系是另外一个重要的课题。
● 思路一:将Dubbo服务的对外接口暴露为REST API
对于Dubbo服务提供者来说,可以通过@RestController封装服务端代码,对外暴露REST API。使用时,我们只需要在调用端的Service中注入InvokeRemoteService就可以像调用本地方法一样进行远程调用:
对于Dubbo服务的消费者,你可以借助Spring Cloud中的Feign作为HTTP REST的调用接口,对于Dubbo服务,你可以向原来对外提供的Service interface类加入@FeignClient注解,支持外部调用,将对外暴露接口加上@RequestMapping或者@RestController注解,并且把接口改成REST风格的,代码如下:
上面的代码中我们声明了一个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依赖:
然后,实现RPC接口定义:
服务端可以支持多协议发布服务:
接着,我们完成对消费端的实现:
在application.properties中添加Dubbo的版本信息和客户端超时信息,向启动类添加@Enable-DubboConfiguration注解,这里我们配置的这些参数会在项目启动时被加载到DubboProperties类中。
最后,实现Dubbo自动化配置:
上 面 我 们 实 现 了 提 供 Dubbo 的 @Service 注 解 服 务 。 在DubboAutoConfiguration配置类中启动Bean,当配置文件中的前缀以“dubbo”开始时,会注入相关配置并完成初始化,然后获取所有加了@Service注解的类,使用反射生成代理类。当我们使用HTTP请求这些由@Service注解的类的方法时,它会将HTTP请求转换成Dubbo请求,调用这个代理类将调用结果返回。
本文给大家讲解的内容是RPC远程过程调用,SpringCloud集成Dubbo
- 下篇文章给大家讲解的内容是RPC远程过程调用,Spring Cloud集成gRPC
- 觉得文章不错的朋友可以转发此文关注小编;
- 感谢大家的支持!
猜你喜欢
- 2025-03-19 spring Boot必用依赖框架(springbootapplication依赖)
- 2025-03-19 Springboot集成Kafka原理(spring集成kafka的原理)
- 2025-03-19 价值32k!阿里顶级架构师深度解析SpringBoot进阶原理实战手册
- 2025-03-19 疯了!Spring 再官宣惊天大漏洞(spring.plus)
- 2025-03-19 SpringBoot、MyBatis、Vue搭建一个Java企业应用开源框架源码分享
- 2025-03-19 springboot的轻量替代框架-Solon(springboot代替ssm框架)
- 2025-03-19 Spring boot 原理,核心原理使用场景
- 2025-03-19 Erupt:开源低代码 全栈类 框架,开发后端系统利器,无商用限制
- 2025-03-19 SpringBoot接入轻量级分布式日志框架(GrayLog)
- 2025-03-19 SpringBoot如何保证接口安全:架构设计与详细实现
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 稳压管的稳压区是工作在什么区 (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)