欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Dubbo的基本介绍及使用

程序员文章站 2022-11-08 13:15:13
一,前言 ​ 在面对新技术新事物的时候,我们首先应该了解这是一个什么东东,了解为什么使用这门技术,如果我们不使用又会有什么影响。比如,本篇博客介绍Dubbo的基本使用,此时我们应该先要明白我为什么要使用Dubbo,它能帮我解决什么问题,不使用Dubbo又会如何。 ​ 关于Dubbo的相关术语,请参考 ......

一,前言

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

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

二,什么是dubbo

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

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

其核心部分包含:

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

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

Dubbo的基本介绍及使用

三,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提供的简单监控中心,可以用来显示接口暴露,注册情况,也可以看接口的调用明细,调用时间等。

​ 下载地址:

​ 3,使用spring boot创建工程。

4.3 创建demo

4.3.1 demo工程结构如下:

Dubbo的基本介绍及使用

4.3.2 springboot_provider工程如下:

Dubbo的基本介绍及使用

在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监控中心。

Dubbo的基本介绍及使用

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

4.3.3 springboot_consumer工程结构如下:

Dubbo的基本介绍及使用

消费者代码如下:

@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监控中心显示:

Dubbo的基本介绍及使用

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

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

Dubbo的基本介绍及使用

且浏览器页面显示如图:

Dubbo的基本介绍及使用

五,总结

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