一,前言

​ 在面对新技术新事物的时候,我们首先应该了解这是一个什么东东,了解为什么使用这门技术,如果我们不使用又会有什么影响。比如,本篇博客介绍Dubbo的基本使用,此时我们应该先要明白我为什么要使用Dubbo,它能帮我解决什么问题,不使用Dubbo又会如何。

​ 关于Dubbo的相关术语,请参考Dubbo官网(支持中英): http://dubbo.apache.org

二,什么是Dubbo

​ Dubbo是一款分布式服务框架,为其提供高性能化和透明化的RPC远程调用的服务方案,致力于解决在SOA服务架构中的协调性。

​ 通俗来说,就是在分布式项目架构中用于同一各个子模块之间的关系。我们都知道在分布式结构的模块中,每个模块单元之间都是相互独立的。那么又该如何将这些独立的模块之间相互联系调用,那么Dubbo服务框架就是用来解决该问题的,这也就是为什么要使用Dubbo框架。

其核心部分包含:

  1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
  2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
  3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

​ Dubbo基本流程图如下(Zookeeper为Dubbo默认的注册中心):

三,Dubbo原理分析

​ dubbo架构如图所示(官网原图):

图中节点说明:

​ Provider: 暴露服务的服务提供方。

​ Consumer: 调用远程服务的服务消费方。

​ Registry: 服务注册与发现的注册中心。

​ Monitor: 统计服务的调用次调和调用时间的监控中心。

​ Container: 服务运行容器。

执行的顺序:

​ 0,先启动生产者;

​ 1,生产者将自己启动的消息报告给注册中心;

​ 2,消费者启动,通知注册中心;

​ 3,注册中心通知消费者有生产者了;

​ 4,消费者消费(调用方法);

​ 5,产者和消费者将自己的调用信息和被调用信息发送监控中心;

注意:在启动项目时,要先启动生产者,并且在注册中心注册成功,才可以启动消费者并且调用成功。

四,Dubbo的使用

​ 以上介绍了很多,但是阐述的也有些官方。那么接下来就直接上代码,并且将运行结果进行展示说明。

4.1 快速启动

​ Dubbo 采用全 Spring 配置方式,透明化接入应用,对应用没有任何 API 侵入,只需用 Spring 加载 Dubbo 的配置即可,Dubbo 基于 Spring 的 Schema 扩展 进行加载。

​ 如果不想使用 Spring 配置,可以通过 API 的方式 进行调用。

4.2 Demo运行环境

​ Dubbo框架以Zookeeper为注册中心,因而我们还应将zookeeper环境准备好。以该博客中demo为例(以下环境安装不再详述,网上有很多优秀的博客):

​ 1,在Linux服务器中准备好zookeeper。

​ 2,准备Tomcat服务器,将dubbo监控中心放置到tomcat的webapp下,直接启动。

​ dubbo监控中心:dubbo-monitor-simple是dubbo提供的简单监控中心,可以用来显示接口暴露,注册情况,也可以看接口的调用明细,调用时间等。

​ 下载地址:https://github.com/apache/incubator-dubbo/releases

​ 3,使用Spring Boot创建工程。

4.3 创建Demo

4.3.1 Demo工程结构如下:

4.3.2 springboot_provider工程如下:

在provider模块中引入dubbo依赖,及zookeeper依赖

<!-- dubbo -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.5.8</version>
</dependency> <!-- zookeeper依赖 -->
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>

编写service层代码如下:

@Service
public class UserServiceImpl implements IUserService { @Override
public User queryUser() {
System.out.println("调用提供者provider");
return new User(1, "小明", 10);
}

​ 到此还有一步,就是还要编写dubbo的配置属性。

<!-- 设置dubbo的名称 -->
<dubbo:application name="dubbo-provide"/> <!-- 指定注册的服务中心 -->
<dubbo:registry protocol="zookeeper" address="192.168.120.56:2181"/> <!-- 暴露服务 -->
<dubbo:protocol name="dubbo" port="20880"/> <!-- 注册服务 -->
<dubbo:service interface="com.yx.dubbo_service.service.IUserService" ref="userServiceImpl" retries="0" timeout="10"></dubbo:service>

​ 此时就可以启动dubbo的提供者,打开之前安装好的dubbo监控中心。

​ 如上图表示提供者已经注册在zookeeper上,并且显示没有消费者。

4.3.3 springboot_consumer工程结构如下:

消费者代码如下:

@Autowired
private IUserService userService; @RequestMapping("/index")
public String index(){
System.out.println("controller被调用");
User user = userService.queryUser();
System.out.println("dubbo消费者为:" + user);
return "OK!!!!";
}

​ 编写消费者dubbo配置属性:

<dubbo:application name="dubbo-consumer"/>

<dubbo:registry protocol="zookeeper" address="192.168.120.56:2181"/>

<!-- 引用服务 -->
<dubbo:reference id="userService" interface="com.yx.dubbo_service.service.IUserService" timeout="1000" />

​ 启动消费者,dubbo监控中心显示:

当提供者和消费者都注册成功时,则显示正常。

最后通过浏览器访问controller层,控制台如图所示:

且浏览器页面显示如图:

五,总结

​ 对于dubbo的基本使用就结束了,但这只是一个简单的入门介绍,dubbo的使用仍有很多功能。由于个人能力有限,因而在该文章中如有不恰当之处,还请各位大牛留言指点,感谢阅读!

Dubbo的基本介绍及使用的更多相关文章

  1. dubbo注册中心介绍

    作者:微子Lee链接:https://www.jianshu.com/p/2f4cfb6ed048 Dubbo的注册中心有好多种,包括Multicast.Zookeeper.Redis.Simple等 ...

  2. RPC理论以及Dubbo的使用介绍

    RPC 的主要功能目标是让构建分布式应用更容易,在提供强大的远程调用能力时不损失本地调用的语义简洁性. 为实现该目标,RPC 框架需提供一种透明调用机制让使用者不必显式的区分本地调用和远程调用. RP ...

  3. dubbo实现原理介绍

      一.什么是dubbo Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合).从服务模型的角度来看,     ...

  4. dubbo的详细介绍

    1.背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 2.架构 单一应用架构 当网站流量很 ...

  5. Dubbo框架入门介绍

    背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时,只需一个 ...

  6. Linux 配置 dubbo 和 dubbo的简单介绍。

    一.是么是  dubbo? 一.dubbo? 1.因为项目之间需要相互调用,达到某种预期的结果 1.1 restful? 门户网站必须要知道用户的登录状态,但是用户的登录状态在登录项目中,所以门户网站 ...

  7. dubbo框架的介绍,应用

    http://www.cnblogs.com/Javame/p/3632473.html

  8. dubbo服务架构介绍

    Provider: 暴露服务的服务提供方. Consumer: 调用远程服务的服务消费方. Registry: 服务注册与发现的注册中心. Monitor: 统计服务的调用次数和调用时间的监控中心. ...

  9. [资料分享]dubbo视频教程流行版

    一.基础篇 第001节–课程介绍 第01节–使用Dubbo对传统工程进行服务化改造的思路介绍 第02节–使用Dubbo对传统工程进行服务化改造 第03节–ZooKeeper注册中心安装 第04节–使用 ...

随机推荐

  1. Bzoj 3624: [Apio2008]免费道路 (贪心+生成树)

    Sample Input 5 7 2 1 3 0 4 5 1 3 2 0 5 3 1 4 3 0 1 2 1 4 2 1 Sample Output 3 2 0 4 3 0 5 3 1 1 2 1 这 ...

  2. 9.22考试 crf的军训 题解

    做这道题时由于第一道题太水了,第一反应是NOIP T2级别的题,需要拿上70~100的分,然后就开始分析,当然最后事实证明我错了…… 这道题当时首先联想到了 NOIP2016愤怒的小鸟 当然,数据范围 ...

  3. 【译】.NET Core 3.0 发布自包含单体可执行程序

    .NET Core 提供的发布应用程序选项 self-contained 是共享应用程序的好方法,因为应用程序的发布目录包含所有组件.运行时和框架.您只需要告诉使用者应用程序的入口 exe 文件,就可 ...

  4. 浅入深出Vue:代码整洁之封装

    深入浅出vue系列文章已经更新过半了,在入门篇中我们实践了一个小小的项目. <代码整洁之道>一书中提到过一句话: 神在细节中 这句话来自20世纪中期注明现代建筑大师 路德维希·密斯·范·德 ...

  5. python 写入excel数据而不改变excel原有样式

    目标:python写数据到excel,不改变原有样式 解决:在打开excel时,加入该参数formatting_info=True

  6. 倍增求LCA学习笔记(洛谷 P3379 【模板】最近公共祖先(LCA))

    倍增求\(LCA\) 倍增基础 从字面意思理解,倍增就是"成倍增长". 一般地,此处的增长并非线性地翻倍,而是在预处理时处理长度为\(2^n(n\in \mathbb{N}^+)\ ...

  7. 15号作品teamfinal使用体验

    通过使用这款软件,可以轻松的查阅所处学期的任意周中某一天中的基教.一教.二教.三教和土木楼中的空教室,方便了同学去寻找空教室的方便,方便同学们上自习,节省寻找教室的时间,提供了非常大的便利. 打开界面 ...

  8. xutils3 上传文件操作——个人小计

    上传文件注意: 使用KeyValue对象进行添加文件操作 int uid = 2; //普通字段的存储 requestParams.addBodyParameter("uid", ...

  9. ieda使用 在jsp页面中,有时候会出现不能智能显示方法 idea pageContext.setAttribute

    idea使用,出现问题记录: 就比如在 pageContext.setAttribute("user",u);这句打pageContext会智能提示, 但是后面的setAttrib ...

  10. SQL server 2014使用导出数据为Excel

    1.打开SQL server 2014,连接至数据库引擎 2.在要导出的数据库上右击,选择"任务->导出数据" 3.数据源选择"SQL Server Native ...