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请求,调用这个代理类将调用结果返回。