不服不行啊!大牛确实把SpringCloud集成Dubbo给一次性讲透了
yuyutoo 2024-10-12 00:16 1 浏览 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请求,调用这个代理类将调用结果返回。
本文给大家讲解的内容是RPC远程过程调用,SpringCloud集成Dubbo
- 下篇文章给大家讲解的内容是RPC远程过程调用,Spring Cloud集成gRPC
- 觉得文章不错的朋友可以转发此文关注小编;
- 感谢大家的支持!
相关推荐
- MySQL5.5+配置主从同步并结合ThinkPHP5设置分布式数据库
-
前言:本文章是在同处局域网内的两台windows电脑,且MySQL是5.5以上版本下进行的一主多从同步配置,并且使用的是集成环境工具PHPStudy为例。最后就是ThinkPHP5的分布式的连接,读写...
- thinkphp5多语言怎么切换(thinkphp5.1视频教程)
-
thinkphp5多语言进行切换的步骤:第一步,在配置文件中开启多语言配置。第二步,创建多语言目录。相关推荐:《ThinkPHP教程》第三步,编写语言包。视图代码:控制器代码:效果如下:以上就是thi...
- 基于 ThinkPHP5 + Bootstrap 的后台开发框架 FastAdmin
-
FastAdmin是一款基于ThinkPHP5+Bootstrap的极速后台开发框架。主要特性基于Auth验证的权限管理系统支持无限级父子级权限继承,父级的管理员可任意增删改子级管理员及权限设置支持单...
- Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示
-
本文实例讲述了Thinkphp5.0框架实现控制器向视图view赋值及视图view取值操作。分享给大家供大家参考,具体如下:Thinkphp5.0控制器向视图view的赋值方式一(使用fetch()方...
- thinkphp5实现简单评论回复功能(php评论回复功能源码下载)
-
由于之前写评论回复都是使用第三方插件:畅言所以也就没什么动手,现在证号在开发一个小的项目,所以就自己动手写评论回复,没写过还真不知道评论回复功能听着简单,但仔细研究起来却无法自拔,由于用户量少,所以...
- ThinkPHP框架——实现定时任务,定时更新、清理数据
-
大家好,我是小蜗牛,今天给大家分享一下,如何用ThinkPHP5.1.*版本实现定时任务,例如凌晨12点更新数据、每隔10秒检测过期会员、每隔几分钟发送请求保证ip的活性等本次分享,主要用到一个名为E...
- BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统
-
BeyongCms内容管理系统(简称BeyongCms)BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统,适用于企业Cms,个人站长等,针对移动App、小程序优化;提供完善简...
- YimaoAdminv3企业建站系统,使用 thinkphp5.1.27 + mysql 开发
-
介绍YimaoAdminv3.0.0企业建站系统,使用thinkphp5.1.27+mysql开发。php要求5.6以上版本,推荐使用5.6,7.0,7.1,扩展(curl,...
- ThinkAdmin-V5开发笔记(thinkpad做开发)
-
前言为了快速开发一款小程序管理后台,在众多的php开源后台中,最终选择了基于thinkphp5的,轻量级的thinkadmin系统,进行二次开发。该系统支持php7。文档地址ThinkAdmin-V5...
- thinkphp5.0.9预处理导致的sql注入复现与详细分析
-
复现先搭建thinkphp5.0.9环境...
- thinkphp5出现500错误怎么办(thinkphp页面错误)
-
thinkphp5出现500错误,如下图所示:相关推荐:《ThinkPHP教程》require():open_basedirrestrictionineffect.File(/home/ww...
- Thinkphp5.0极速搭建restful风格接口层
-
下面是基于ThinkPHPV5.0RC4框架,以restful风格完成的新闻查询(get)、新闻增加(post)、新闻修改(put)、新闻删除(delete)等server接口层。1、下载Thin...
- 基于ThinkPHP5.1.34 LTS开发的快速开发框架DolphinPHP
-
DophinPHP(海豚PHP)是一个基于ThinkPHP5.1.34LTS开发的一套开源PHP快速开发框架,DophinPHP秉承极简、极速、极致的开发理念,为开发集成了基于数据-角色的权限管理机...
- ThinkPHP5.*远程代码执行高危漏洞手工与升级修复解决方法
-
漏洞描述由于ThinkPHP5框架对控制器名没有进行足够的安全检测,导致在没有开启强制路由的情况下,黑客构造特定的请求,可直接GetWebShell。漏洞评级严重影响版本ThinkPHP5.0系列...
- Thinkphp5代码执行学习(thinkphp 教程)
-
Thinkphp5代码执行学习缓存类RCE版本5.0.0<=ThinkPHP5<=5.0.10Tp框架搭建环境搭建测试payload...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- MySQL5.5+配置主从同步并结合ThinkPHP5设置分布式数据库
- thinkphp5多语言怎么切换(thinkphp5.1视频教程)
- 基于 ThinkPHP5 + Bootstrap 的后台开发框架 FastAdmin
- Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示
- thinkphp5实现简单评论回复功能(php评论回复功能源码下载)
- ThinkPHP框架——实现定时任务,定时更新、清理数据
- BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统
- YimaoAdminv3企业建站系统,使用 thinkphp5.1.27 + mysql 开发
- ThinkAdmin-V5开发笔记(thinkpad做开发)
- thinkphp5.0.9预处理导致的sql注入复现与详细分析
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)