美文网首页alreadydubbospringcloud
不服不行啊!大牛确实把SpringCloud集成Dubbo给一次

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

作者: 马小莫QAQ | 来源:发表于2022-03-11 16:47 被阅读0次

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

相关文章

  • 不服不行啊!大牛确实把SpringCloud集成Dubbo给一次

    Spring Cloud集成Dubbo 目前Dubbo在国内还是有较多公司在使用的,一方面是因为Dubbo作为阿里...

  • 不服年龄确实不行

    最近一直在背东西,可是早上背完晚上感觉就模糊了,而晚上背完第二天又感觉模糊了! 确实有点无语,和媳妇说了下。媳妇说...

  • 不服不行啊

    健康宝是人人出门必备的软件。大概九月份刚更新的个人照片,今天又提式需要重新更新才可以用此软件。 打开摄像头照照大头...

  • 坦诚的内心,无力的言语

    浦哥,嫂子真是伶牙俐齿、巧舌如簧,不服都不行啊,哈哈! 可上周卡价确实涨了;公司通知,群里也都发了;兄弟也诚心给您...

  • 不服老不行啊

    才三年,我是经历多少沧桑。 不经意翻到三年前的照片,暗自感叹,生活的磨难为何这么准确的降临在了自己的身上,是倒霉还...

  • 不服老不行啊😂

    亲自日记第677篇 一夜之间感觉整个城都冷了,不太喜欢的冬天依旧如约而至。早上送孩子们上学的时候,真的是太冷...

  • 不服老不行啊

    总认为自己没有什么年龄的障碍,当同龄的女子担心法令纹、鱼尾纹、脖颈纹的时候,我完全没有过担心,我觉得自己依旧是多年...

  • 不服老不行啊

    昨天下午,查看安装在老家的监控,通过回放,发现母亲下午4点多才吃午饭。感觉不对劲,母亲一般都是12点左右吃午饭的,...

  • 协议:SpringCloud VS Dubbo

    SpringCloud 和 Dubbo 协议的对比

  • 如何上手使用duboo-springcloud

    如何上手使用duboo-springcloud dubbo-springcloud gihub地址 直连模式 依赖...

网友评论

    本文标题:不服不行啊!大牛确实把SpringCloud集成Dubbo给一次

    本文链接:https://www.haomeiwen.com/subject/ikfhdrtx.html